# Application Notes and Development Tools for 80C51 Microcontrollers 1995 **DATA HANDBOOK** PHILIPS **PHILIPS** #### **QUALITY ASSURED** Our quality system focuses on the continuing high quality of our components and the best possible service for our customers. We have a three-sided quality strategy: we apply a system of total quality control and assurance; we operate customer-oriented dynamic improvement programmes; and we promote a partnering relationship with our customers and suppliers. #### PRODUCT SAFETY In striving for state-of-the-art perfection, we continuously improve components and processes with respect to environmental demands. Our components offer no hazard to the environment in normal use when operated or stored within the limits specified in the data sheet. Some components unavoidably contain substances that, if exposed by accident or misuse, are potentially hazardous to health. Users of these components are informed of the danger by warning notices in the data sheets supporting the components. Where necessary the warning notices also indicate safety precautions to be taken and disposal instructions to be followed. Obviously users of these components, in general the set-making industry, assume responsibility towards the consumer with respect to safety matters and environmental demands. All used or obsolete components should be disposed of according to the regulations applying at the disposal location. Depending on the location, electronic components are considered to be 'chemical', 'special' or sometimes 'industrial' waste. Disposal as domestic waste is usually not permitted. # Application Notes and Development Tools for 80C51 Microcontrollers ## **CONTENTS** | | | page | |------------|-------------------------------------------------------------|------| | SECTION 1 | GENERAL INFORMATION | 5 | | SECTION 2 | INTER-INTEGRATED CIRCUIT (I <sup>2</sup> C) BUS | 37 | | SECTION 3 | I <sup>2</sup> C SERIAL BUS APPLICATION NOTES<br>& ARTICLES | 65 | | SECTION 4 | ACCESS.bus TECHNICAL OVERVIEW | 273 | | SECTION 5 | ACCESS.bus APPLICATION NOTES<br>& ARTICLES | 289 | | SECTION 6 | CONTROL AREA NETWORK (CAN) BUS | 333 | | SECTION 7 | 87C750, 8XC751, 8XC752<br>APPLICATION NOTES | 413 | | SECTION 8 | OTHER 80C51 APPLICATION NOTES<br>& ARTICLES | 575 | | SECTION 9 | DEVELOPMENT SUPPORT TOOLS | 757 | | APPENDIX A | DATA HANDBOOK SYSTEM | 842 | | | | | # **Preface** Application Notes and Development Tools for 80C51 Microcontrollers #### Microcontrollers from Philips Semiconductors core and instruction set, in "Data Handbook IC03". Philips Semiconductors 8 and 16-bit microcontrollers are based on the widely-accepted 8048, 8051 and 68000 architectures. We offer most of the 'industry standard' products in these architectures as well as a large selection of powerful derivative products. These derivatives offer a wide assortment of features, including: additional memory, A/D, PWM, additional timers, DTMF, OSD, OTP, EMC and EMI, plus many others. The variety of product derivatives allows Philips Semiconductors to support a broad range of functions in consumer, telecom, EDP, multi media, automotive and industrial applications. #### For details, see: - 8048 'industry standard' architecture types (PCF84CXXX family) in "Data Handbook IC14". The PCD33XX family covers telecom terminal family devices based on the 8048 - 8051 'industry standard' architecture types in "Data Handbook IC20". - 68000 compatible 'industry standard' architecture types in "Data Handbook IC21". The Low Power 80CL51 family of derivatives can be found in "Data Handbook IC20". These devices operate over the wide voltage range of 1.8 to 6.0V and are ideal for portable and battery operations. Many of Philips Semiconductors ICs offer on-board UART serial ports and I $^2$ C-bus. The I $^2$ C-bus allows easy connection to over 100 other devices, thereby increasing system capabilities even further. We also offer the Philips/Digital Equipment Corporation ACCESS.bus, a new Standard Desktop bus. And for automotive and industrial applications, we also offer the CAN and the VAN serial bus. The CAN standard, developed by Bosch, and VAN concepts offer high noise immunity and error correction. Philips Semiconductors 16-bit microcontroller family is based on the 68000 architecture. While these are called 16-bit microcontrollers, the 68000 CPU core architecture is a 32-bit. This offers the user a great deal more processing power when the need arises in a design to move from an 8-bit to a 16-bit microcontroller. Philips Semiconductors 16-bit microcontrollers are software compatible with existing 68000 code. Future developments include the introduction of SPARC and Trimedia devices. Philips Semiconductors is developing a family of 16-bit microcontrollers based on the 8051 'XA' (eXtended Architecture). This family of microcontrollers will offer advanced performance for those applications that are computation and memory intensive in an embedded control environment # **Philips Semiconductors** # **Section 1**General Information Application Notes and Development Tools for 80C51 Microcontrollers #### **CONTENTS** | Contents | 7 | |-----------------------------------------------------------|----| | Product Status | 13 | | 80C51 microcontroller family features guide | 14 | | 8051 microcontroller cross-reference guide | 18 | | Low power / low voltage microcontroller family | 19 | | 80C51 microcontroller development system support | 20 | | 8-bit microcontroller demonstration and evaluation boards | 22 | | Microcontroller bulletin boards | 23 | | Philips Fax-On-Demand System | 24 | | CMOS and NMOS 8-bit microcontroller family | 25 | | CMOS 16-bit microcontroller family | 33 | | Ordering information | 24 | # APPLICATION NOTES AND DEVELOPMENT TOOLS FOR 80C51 MICROCONTROLLERS | | Preface | | 3 | |-----|--------------------------------------------|------------------------------------------------------------|------------| | Sec | ection 1 – General Informatio | | | | | | | | | | Product Status | | 7 | | | 90C51 microcontroller femile | factories and de | 13 | | | 9051 microcontroller farmi | features guide | 14 | | | 6051 Microcontroller cross- | eference guide | 18 | | | Low power / low voltage mid | ocontroller family | 19 | | | 80C51 microcontroller deve | opment system support | 20 | | | 8-bit microcontroller demon | tration and evaluation boards | 22 | | | Microcontroller bulletin boar | s | 23 | | | Philips Fax-On-Demand Sys | tem | 24 | | | CMOS and NMOS 8-bit mic | ocontroller family | 25 | | | CMOS 16-bit microcontrolle | family | 33 | | | Ordering information | | 34 | | Sec | ction 2 - Inter-Integrated Cir | wit (120) Burn | | | | | | | | | I <sup>2</sup> C peripheral selection quie | | 39 | | | 82B715 | 3 | 58 | | | | | 60 | | Sec | ction 3 – I <sup>2</sup> C Serial Bus App | cation Notes & Articles | | | | AN422 Using t | e 8XC751 microcontroller as an I <sup>2</sup> C bus master | 67 | | | AN425 Interfac | N DODOGO 4 120 1 | 85 | | | AN430 Using the | - 0\/0754/750 ' 10' 1 10' 1 10' 11 11 | 104 | | | AN433 I <sup>2</sup> C slav | | 140 | | | AN434 Connec | | 146 | | | AN438 I <sup>2</sup> C rou | ( 0)/0=00 | 164 | | | AN444 Using t | | 186 | | | ETV/AN89004 PLM51 | | 206 | | | EIE/AN91007 I <sup>2</sup> C driv | | | | | Programming the I <sup>2</sup> C interfa | | 215 | | _ | | | 269 | | Sec | ction 4 - ACCESS.bus Tech | | | | | ACCESS.bus Technical Ove | view 2 | 275 | | | Introduction | | 275 | | | What is ACCESS.bus | ? 2 | 275 | | | ACCESS.bus Hardw | re 2 | 275 | | | ACCESS.bus Protoc | ls 2 | 276 | | | HOW ACCESS bus Work | 2 | 277 | | | Pue Transations | | 277 | | | Supply animation | | 277 | | | Byte Framing and As | Poulddomont 2 | 279 | | | Addressing | | 279 | | | Arbitration | | 279 | | | Message Format | | 279 | | | Control/Status Messa | | 279<br>279 | | | Configuration | | 280 | | | Device Identifiers | | 281 | | | Device Capabilities Ir | | 281 | | | Application Device Types | | 282 | | | Keyboard Devices | | 82 | | | Locator Devices | | 82 | | | Text Devices | | 82 | | | Timing Rules | | 82 | | | Transaction Timing R | lles | 82 | | | Response Timeouts | | 82 | | | Software Architecture an | I Development | 82 | | | Device Firmware Dev | elopment | 283 | | | nost Software Archite | cture | 83 | | | | | | | | ACCESS.bus | pport | 283<br>283<br>283 | |-----|-----------------------|----------------------------------------------------------------------------------------------------------|-------------------| | | Philips Semic | onductors Supportopment kit | 284 | | | ACCESS.bus PC/AT | controller board | 286 | | Sec | tion 5 – ACCESS.bu | s Application Notes & Articles | | | | AN445 | ACCESS.bus mouse application code for the 8XC751 microcontroller | ion / | | | Issues in desktop co | nnectivity | 291 | | | Finally, a plug-and-p | lay solution | 295 | | | Special Report: ACC | DESS.bus Specs And Products | 297 | | | ACCESS.bus: A Ne | w Peripheral Bus | 299 | | | | sing ACCESS.bus | 301 | | | | us interface card | 309 | | | Taking a new bus . | | 312 | | | Personal Digital Ass | istants: What's missing? | 318 | | | The portable deskto | p: New connections for today's mobile user | 320 | | | Who's hopping on the | ne ACCESS.bus? | 322 | | | ACCESS.bus revisit | ted—ending the peripheral connection nightmare | 324 | | | Seriously serial | | 327 | | Sec | tion 6 - Control Are | a Network (CAN) Bus | | | | Control Area Netwo | rk (CAN) overview | 335 | | | 82C150 | CAN serial linked I/O device (SLIO) with digital and analog port functions | 336 | | | 82C200 | Stand-alone CAN-controller | 365 | | | PCA82C250 | CAN controller interface | 401 | | Sec | tion 7 – 87C750, 8X | C751, 8XC752 Application Notes | | | | AN422 | Using the 8XC751 microcontroller as an I <sup>2</sup> C bus master | tion 3 | | | AN423 | Software driven serial communication routines for the 83C751 and 83C752 microcontrollers | 415 | | | AN426 | Controlling air core meters with the 87C751 and SA5775 | 420 | | | AN427 | Timer I for the 83/87C748/749 and the 83/87C751/752 (non-I <sup>2</sup> C applications) microcontrollers | 434 | | | AN428 | Using the ADC and PWM of the 83C752/87C752 | 440 | | | AN429 | Airflow measurement using the 83/87C752 and "C" | 447 | | | AN430 | Using the 8XC751/752 in multimaster I <sup>2</sup> C applications | | | | AN433 | I <sup>2</sup> C slave routines for the 83C751 See Sec | | | | AN436 | "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller | 466 | | | AN439 | 87C751 fast NiCad charger | 476 | | | AN442 | (BCM) 87C751 Specification for a bus-controlled monitor | 488 | | | AN445 | ACCESS.bus mouse application code for the 8XC751 microcontroller | 505 | | | AN446 | A software duplex UART for the 751/752 | 535 | | | AN453 | Using the 87C751 microcontroller to gang program PCF8582/PCF8581 EEPROMs | 543 | | | AN454 | Interfacing the 83C576/87C576 to the ISA bus | 562 | | | EIE/AN91007 | I <sup>2</sup> C driver routines for 8XC751/2 microcontrollers | SHOII 3 | | Sec | ction 8 - Other 80C5 | 1 Application Notes & Articles | | | | AN408 | 80C451 operation of port 6 | 577 | | | AN417 | 256k Centronics printer buffer using the 87C451 microcontroller | 588 | | | AN418 | Counter/timer 2 of the 83C552 microcontroller | 601 | | | AN420 | Using up to 5 external interrupts on 80C51 family microcontrollers | 608 | | | AN424 | 8051 family warm boot determinations | 610 | | | AN440 | RAM loader program for 80C51 family applications | 612 | | | AN443 | IEEE Micro Mouse using the 87C751 microcontroller | 621 | | | AN447 | Automatic baud rate detection for the 80C51 | 642 | | | AN448 | Determining baud rates for 8051 UARTs and other UART issues | 645 | | | ESG89001 | Electro magnetic compatibility and printed circuit board (PCB) constraints | 648 | | | EIE/AN91001 | Workbench EMC evaluation method | 667<br>684 | | | EIE/AN91006 | A/D conversion with P83CL410 PCF1252-x | 700 | | | EIE/AN91009 | Driver for 8xC851 E2PROM | 715 | | | EIE/AN92001 | Low hr-emission applications with a P830E654 microcontroller | / 15 | | | EIE/AN93017 Using the analog-to-digital converter of the 8XC552 microcontroller | 727 | |-----|-----------------------------------------------------------------------------------------|-----| | | Chips push CAN bus into embedded world | 745 | | | Add Text Overlay to Any Video Display | 747 | | Sec | ction 9 – Development Support Tools | | | | Development support tools | 200 | | | Ashling CTS51 Microprocessor development systems for Philips microcontrollers | 759 | | | BSO/Tasking: The total development solution for the 8051 family | 766 | | | CEIBO DB-51 Development Board | 771 | | | CEIBO DS-51 In-Circuit Emulator | 778 | | | CEIBO DS-51 In-Circuit Emulator CEIBO DS-300 Paripheral Payalonment Teals | 780 | | | CEIBO DS-300 Peripheral Development Tools CEIBO DS-750 Microcontroller Development Tool | 788 | | | CEIBO DS-750 Microcontroller Development Tool | 790 | | | CEIBO DS-752 Microcontroller Development Tool | 792 | | | CEIBO EB-51 Emulation Board | 794 | | | CEIBO MP-51 Programmer | 796 | | | MetaLink iceMASTER-PE 8051 Family In-Circuit Emulator | 798 | | | MetaLink IceMASTER 8051 Family In-Circuit Emulators | 803 | | | NORAU EMUL51-PC – PC-based in-circuit emulator | 016 | | | PDS51 Development System for 8XC51 Microcontroller Derivatives | 927 | | | LCP Programmers for 87C51 and Derivatives | 831 | | | S87C00KSD 8XC51 and I-C Bus Evaluation Board | 024 | | | OM4130 CAN evaluation board with the 8XC552 and 82C200 CAN controller | 925 | | | OM4239 CAN evaluation board with the 8XC592 microcontroller | 000 | | | OM4240 Evaluation board for the 8XCE598 microcontroller | 836 | | | OM4272 SLIO evaluation board with the 82C150 and 82C250 CAN ICs | 837 | | | OM4280 P83C852 Smart Card crypto-controller demonstration kit | 838 | | | PEB552 Evaluation board | | | | | 840 | | pp | pendix A – Data Handbook System | 842 | # IC20: 80C51-BASED 8-BIT MICROCONTROLLERS | Preface | | 3 | |------------------------------------|-------------------------------------------------------------------------------|------------| | Section 1 – General Information | | | | Contents | | 7 | | Product Status | | 13 | | 80C51 microcontroller family fea | tures guide | 14 | | 9051 microcontroller cross-refere | ence quide | 18 | | Low power / low voltage microco | ntroller family | 19 | | 90C51 microcontroller developm | ent system support | 20 | | 9 bit microcontroller demonstrati | on and evaluation boards | 22 | | Microcontroller bulletin hoards | | 23 | | Philips Fay On Domand System | | 24 | | CMOS and NIMOS 8-bit microco | ntroller family | 25 | | CMOS 16-bit microcontroller fam | illy | 33 | | Ordering information | ······································ | 34 | | | | | | Section 2 – 80C51 Technical Descri | ption | 39 | | 80C51 architecture | | 54 | | 80C51 hardware description | | 79 | | 80C51 programmer's guide and | instruction set | 134 | | 80C51 EPROM products | | 104 | | Section 3 – 80C51 Family Derivativ | es | | | 80C31/80C51/87C51 | CMOS single-chip 8-bit microcontroller | 141 | | 80C51FA/83C51FA/87C51FA | CMOS single-chip 8-bit microcontroller | 159 | | 83C51FB/87C51FB | CMOS single-chip 8-bit microcontrollers | 187 | | 83C51FC/87C51FC | CMOS single-chip 8-bit microcontrollers | 214 | | 80CL31/80CL51 | Low-voltage single-chip 8-bit microcontrollers | 242 | | 83L51FA/87L51FA | CMOS single-chip 3.0V 8-bit microcontroller | 276 | | 83L51FB/87L51FB | CMOS single-chip 3.0V 8-bit microcontroller | 292 | | 80C32/80C52/87C52 | CMOS single-chip 8-bit microcontrollers | 308 | | 80C54/87C54 | CMOS single-chip 8-bit microcontrollers | 329 | | 80C58/87C58 | CMOS single-chip 8-bit microcontrollers | 349 | | 83C055/87C055 | Microcontroller for television and video (MTV) | 369 | | P83CL168; P83CL167 | | | | P83CL268; P83CL267 | Microcontroller for TV OSD, VST and control functions | 388 | | 80CL410/83CL410 | Low voltage/low power single-chip 8-bit microcontroller with I <sup>2</sup> C | 485 | | 80C451/83C451/87C451 | CMOS single-chip 8-bit microcontroller | 507 | | 80C453/83C453/87C453 | CMOS single-chip 8-bit microcontroller | 527 | | 83C504/87C504 | CMOS single-chip 8-bit microcontroller | 550 | | 83C508/87C508 | CMOS single-chip 8-bit microcontroller | 568 | | P83C524 | 8-bit microcontroller | 585 | | 87C524 | CMOS single-chip 8-bit microcontroller | 606 | | 80C528/83C528 | CMOS single-chip 8-bit microcontroller | 626 | | 87C528 | CMOS single-chip 8-bit microcontroller | 644 | | P8xCE528 | 8-bit microcontroller with EMC | 666 | | 83C542/87C542 | ACCESS.bus™ microcontroller | 693 | | 80C550/83C550/87C550 | CMOS single-chip 8-bit microcontroller with A/D and watchdog timer | 715 | | 8XC552/562 overview | | 739 | | 8XC552 OVERVIEW | | 739 | | 83C562 OVERVIEW | | 739<br>739 | | Differences From the 80 | C51 | | | Program Memory | | | | Data Memory | gisters | | | Special Function Re<br>Timer T2 | yisters | 740 | | Timer T3. The Watch | ndog Timer | 746 | | Serial I/O | | 747 | | | | | | | Reset | Circuitry | | 780 | |-----|---------------------------|---------------------|---------------------------------------------------------------------------------------------------|------------| | | Interru | pts | | 781 | | | I/O Poi | rt Structure | | 785 | | | Port 1 | Operation | | 785 | | | Port 5 | Operation | | 785 | | | | | 1 Outputs | | | | | | erter | | | | | | 98 | 791<br>793 | | | 80C552/83C552 | y Organization . | Single-chip 8-bit microcontroller with 10-bit A/D, capture/compare timer, high-speed outputs, PWM | | | | 87C552 | | | | | | | ===0/ | Single-chip 8-bit microcontroller with 10-bit A/D, capture/compare timer, high-speed outputs, PWM | 818 | | | P83CE558/P80C<br>P89CE558 | E558/ | Cingle ship 0 hit misses saturily | | | | | | Single-chip 8-bit microcontroller | 839 | | | P83CE559/P80C | ,E339 | Single-chip 8-bit microcontroller | 908 | | | 80C562/83C562 | | Single-chip 8-bit microcontroller with 8-bit A/D, capture/compare timer, high-speed outputs, PWM | 976 | | | 80C575/83C575/ | /87C575 | CMOS single-chip 8-bit microcontroller | 989 | | | 83C576/87C576 | | CMOS single-chip 8-bit microcontroller | | | | 80CL580/83CL5 | 80 | Low-voltage single-chip 8-bit microcontroller | 1063 | | | P8XC592 | | 8-bit microcontroller with on-chip CAN | | | | P8XCE598 | | 8-bit microcontroller with on-chip CAN | | | | 80C652/83C652 | | CMOS single-chip 8-bit microcontroller | | | | 87C652 | | CMOS single-chip 8-bit microcontroller | | | | 83C654 | | CMOS single-chip 8-bit microcontroller | | | | 87C654 | | CMOS single-chip 8-bit microcontroller | | | | 83CE654 | | CMOS single-chip 8-bit microcontroller with Electromagnetic Compatibility improvements | | | | 83C748/87C748 | | CMOS single-chip 8-bit microcontroller | | | | 83C749/87C749 | | CMOS single-chip 8-bit microcontroller | 1404 | | | 83C750/87C750 | | CMOS single-chip 8-bit microcontrollers | 1429 | | | 83C751/87C751 | | CMOS single-chip 8-bit microcontroller | | | | 83C752/87C752 | | CMOS single-chip 8-bit microcontroller with A/D, PWM | | | | 83CL781/83CL7 | 82 | Low-voltage single-chip 8-bit microcontrollers | 1467 | | | 80C851/83C851 | - | CMOS single-chip 8-bit microcontroller with on-chip EEPROM | | | _ | | | | 1518 | | Sec | tion 4 – High Per | formance 16-bi | t 80C51 XA (eXtended Architecture) | | | | | ectural overview | | 1535 | | | XA-G3 | | CMOS single-chip 16-bit microcontroller | 1545 | | | 80C51XA Develo | opment tools | | 1557 | | Sec | tion 5 – Package | Outlines | | | | | Plastic Dual In-L | | | | | | | | ne package; 8 leads (300 mil)SOT97-1 | 1562 | | | | 24-pin (300 mils | wide) plastic dual in-line (N) package | 1564 | | | DIP28: | plastic dual in-lir | ne package; 28 leads (600 mil) | 1504 | | | | 28-pin (600 mils | wide) plastic dual in-line (N) package | 1565 | | | DIP40: | plastic dual in-lir | ne package; 40 leads (600 mil) | 1500 | | | Plastic Shrink D | | | 1307 | | | | | radge<br>ial in-line package; 42 leads (600 mil)SOT270-1 | 1500 | | | SDIP64: | plastic shrink du | lal in-line package; 64 leads (750 mil) SOT274-1 SOT274-1 | 1568 | | | | | as in into publicago, 04 tourid (750 tilli) | 1569 | | | Ceramic Dual In | | wide) Coromic Duel In line (E) Bookers (with Mindow (EA) Bookers) | | | | | 28-Pin (600 mile | s wide) Ceramic Dual In-line (F) Package (with Window (FA) Package) | 15/0 | | | | 40-Pin (600 mile | s wide) Ceramic Dual In-line (F) Package (with Window (FA) Package)0590B | 15/1 | | | | | s wide) Ceramic Dual maine (r) Fackage (with window (FA) Package) | 1572 | | | Plastic Leaded | | wide) Plactic Leaded Chip Carrier (A) Package | | | | | 44-Pin Plastic L | s wide) Plastic Leaded Chip Carrier (A) Package | 1573 | | | | 44-nin nlastic le | aded chip carrier; pocket version (A) package | 1574 | | | PLCC68: | plastic leaded of | hip carrier; 68 leads | 1575 | | | | | eaded Chip Carrier (A) Package | 15/6 | | | | | | | | | | LOUIS Complex | | | |-----|-------------------------|-----------------------------------------------------------------------------------------------------------|-------------|------| | | Ceramic Leade | 44-pin CerQuad J-Bend (K) Package | . 1472A | 1578 | | | | 68-pin CerQuad J-Bend (K) Package | . 1473A | 1579 | | | | 68-Pin Chip Carrier, J-Bend (L) Package | . 1240C | 1580 | | | | Ceramic leaded chip carrier (window); 68 leads | . NO330 | 1581 | | | Plastic Quad F | let Package | | | | | QFP44: | plastic guad flat package: 44 leads (lead length 1.3 mm); body 10 x 10 x 1.75 mm | . SOT307-2 | 1582 | | | | 44-lead guad flat-pack: plastic | . SOT205AG | 1583 | | | LQFP44: | plastic low profile guad flat package: 44 leads; body 10 x 10 x 1.4 mm | . SOT389-1 | 1584 | | | QFP64: | plastic quad flat package; 64 leads (lead length 2.35mm); body 14 x 20 x 2.75mm | . SOT208-1 | 1585 | | | QFP64: | plastic quad flat package; 64 leads (lead length 1.95mm); body 14 x 20 x 2.7mm;<br>high stand-off height | | | | | QFP80: | plastic quad flat package; 80 leads (lead length 1.95mm); body 14 x 20 x 2.7 mm;<br>high stand-off height | . SOT318-1 | 1587 | | | Ceramic Quad<br>CQFP80: | Flat Package ceramic quad flat package; 80 leads | . SOT351-1 | 1588 | | | Plastic Small ( | Dutline Package | | 4500 | | | SO8: | plastic small outline package; 8 leads; body width 3.9mm | . SOT96-1 | 1589 | | | SO28: | plastic small outline package; 28 leads; body width 7.5mm | . SOT136-1 | 1590 | | | VSO40: | plastic very small outline package; 40 leads | . SOI 158-1 | 1591 | | | VSO56: | plastic very small outline package; 56 leads | . SOT190-1 | 1592 | | | Plastic Shrink | Small Outline Package | | | | | SSOP24: | plastic shrink small outline package; 24 leads; body width 5.3mm | SOT340-1 | 1593 | | | SSOP28: | plastic shrink small outline package; 28 leads; body width 5.3mm | SOT341-1 | 1594 | | | | 42-Pin Plastic SSOP (Shrink Small Outline Package) Dual In-Line (D/K) Package | 1680 | 1595 | | ٩pı | pendix A – Data | Handbook System | | 1596 | | | | Configurations | | | | Aρι | pendix B – Pin ( | Configurations | | | # **Product Status** 80C51-Based 8-Bit Microcontrollers | | DE | FINITIONS | |------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Data Sheet<br>Identification | Product Status | Definition | | Objective Specification | Formative or in Design | This data sheet contains the design target or goal specifications for product development. Specifications may change in any manner without notice. | | Preliminary Specification | Preproduction Product | This data sheet contains preliminary data, and supplementary data will be published at a later date. Philips Semiconductors reserves the right to make changes at any time without notice in order to improve design and supply the best possible product. | | Product Specification | Full Production | This data sheet contains Final Specifications. Philips<br>Semiconductors reserves the right to make changes at any time<br>without notice, in order to improve design and supply the best<br>possible product. | | | Part Number | | Memory | | Counter | I/O | Serial | External | Comments/ | | | |-----------|-------------------|--------------------------------------------------|--------------------------------------------------|-----|----------------------|-------|------------------------|-----------|-------------------------------------------------------------------------------------|--|--| | (ROMIess) | | ROM EPRM | | RAM | Timers | Port | Interfaces | Interrupt | Special Features | | | | Р | 83C750 | 1K | | 64 | 1 (16-bit) | 2-3/8 | | 2 | 40 MHz, Lowest cost, SSOP | | | | Р | 87C750 | | - 1K | 64 | 1 (16-bit) | 2-3/8 | - | 2 | 40 MHz, Lowest cost, SSOP | | | | Р | 83C748 | 2K | | 64 | 1 (16-bit) | 2-3/8 | • | 2 | 8XC751 w/o I <sup>2</sup> C, SSOP | | | | Р | 87C748 | | 2K | 64 | 1 (16-bit) | 2-3/8 | - | 2 | 8XC751 w/o I <sup>2</sup> C, SSOP | | | | s | 83C751 | 2K | | 64 | 1 (16-bit) | 2-3/8 | I <sup>2</sup> C (bit) | 2 | 24-pin Skinny DIP, SSOP | | | | s | 87C751 | | 2K | 64 | 1 (16-bit) | 2-3/8 | I <sup>2</sup> C (bit) | 2 | 24-pin Skinny DIP, SSOP | | | | P | 83C749 | 2K | | 64 | 1 (16-bit) | 2-5/8 | - | 2 | 8XC752 w/o I <sup>2</sup> C, SSOP | | | | Р | 87C749 | | 2K | 64 | 1 (16-bit) | 2-5/8 | - | 2 | 8XC752 w/o I <sup>2</sup> C, SSOP | | | | s | 83C752 | 2K | | 64 | 1 (16-bit) | 2-5/8 | I <sup>2</sup> C (bit) | 2 | 5 Channel 8-bit A/D, PWM Output, SSOP | | | | s | 87C752 | <b>-</b> | 2K | 64 | 1 (16-bit) | 2-5/8 | I <sup>2</sup> C (bit) | 2 | 5 Channel 8-bit A/D, PWM Output, SSOP | | | | MAx | 8051AH (8031AH) | 4K | | 128 | 2 | 4 | UART | 2 | NMOS | | | | sc | 80C51 (80C31) | 4K | | 128 | 2 | 4 | UART | 2 | CMOS (Sunnyvale) | | | | PCx | 80C51 (80C31) | 4K | | 128 | 2 | 4 | UART | 2 | CMOS (Hamburg) | | | | sc | 87C51 | - 7 | 4K | 128 | 2 | 4 | UART | 2 | CMOS | | | | Р | 80CL51 (80CL31) | 4K | | 128 | 2 | 4 | UART | 10 | Low Voltage (1.8V to 6V), Low Power | | | | P | 83CL410 (80CL410) | 4K | | 128 | 2 | 4 | I <sup>2</sup> C | 10 | Low Voltage (1.8V to 6V), Low Power | | | | SC | 83C451 (80C451) | 4K | | 128 | 2 | 7 | UART | 2 | Extended I/O, Processor Bus Interface | | | | SC | 87C451 | | 4K | 128 | 2 | 7 | UART | 2 | Extended I/O, Processor Bus Interface | | | | Р | 83C550 (80C550) | 4K | | 128 | 2 + Watchdog | 4 | UART | 2 | 8 Channel 8-bit A/D | | | | P | 87C550 | 1 | 4K | 128 | 2 + Watchdog | 4 | UART | 2 | 8 Channel 8-bit A/D | | | | P | 83C851 (80C851) | 4K | <del> </del> | 128 | 2 | 4 | UART | 2 | 256B EEPROM, 80C51 Pin compatible | | | | P | 83C542 | 4K | <del> </del> | 256 | 2 | 1 | I <sup>2</sup> C | 2 | ACCESS.bus, replaces 8042 KB controller | | | | P | 87C542 | | 4K | 256 | 2 | 1 | I <sup>2</sup> C | 2 | See Above | | | | P | 83C852 | 6K | | 256 | 2 (16-bit) | 2/8 | - | 1 | Smartcard Controller with 2K EEPROM (Data,<br>Code) Cryptographic Calc Unit | | | | Р | 83CL580 (80CL580) | 6K | | 256 | 3 + Watchdog | 5 | UART, I <sup>2</sup> C | 9 | 4 Channel 8-bit A/D, PWM Output,<br>Low Voltage (2.5V to 6V), Low Power | | | | MAx | 8052AH (8032AH) | 8K | + | 256 | 3 | 4 | UART | 2 | NMOS | | | | P | 80C52 (80C32) | 8K | - | 256 | 3 | 4 | UART | 2 | 80C51 Pin Compatible | | | | P | 87C52 | + | 8K | 256 | 3 | 4 | UART | 2 | (see above) | | | | P | 83C652 (80C652) | 8K | 1 | 256 | 2 | 4 | UART, I <sup>2</sup> C | 2 | 80C51 Pin Compatible | | | | s | 87C652 | + | 8K | 256 | 2 | 4 | UART, I <sup>2</sup> C | 2 | (see above) | | | | P | 83C453 (80C453) | 8K | <del> </del> | 256 | 2 | 7 | UART | 2 | Extended I/O, Processor Bus Interface | | | | P | 87C453 | + | 8K | 256 | 2 | 7 | UART | 2 | Extended I/O, Processor Bus Interface | | | | s | 83C51FA (80C51FA) | 8K | + | 256 | 3 + PCA | 4 | UART | 2 | Enhanced UART, 3 timers + PCA | | | | s | 87C51FA | + | 8K | 256 | 3 + PCA | 4 | UART | 2 | Enhanced UART, 3 timers + PCA | | | | S | 83L51FA | 8K | + | 256 | 3 + PCA | 4 | UART | 2 | Low Voltage 83C51FA (3V @ 20MHz) | | | | s | 87L51FA | + | 8K | 256 | 3 + PCA | 4 | UART | 2 | Low Voltage OTP 87C51FA (3V @ 20MHz) | | | | P | 83C575 (80C575) | 8K | 1 | 256 | 3 + PCA+<br>Watchdog | 4 | UART | 2 | High Reliability, with Low Voltage Detect, OSC Fail Detect, Analog Comparators, PCA | | | | P | 87C575 | 1 | 8K | 256 | (see above) | 4 | UART | 2 | (see above) | | | | P | 83C576 (80C576) | 8K | | 256 | 3 + PCA+<br>Watchdog | 4 | UART | 2 | Same as 8XC575 plus UPI and 10-bit A/D | | | | P | 87C576 | + | 8K | 256 | (see above) | 4 | UART | 2 | (see above) | | | | PC | 83C562 (80C562) | 8K | | 256 | 3 + Watchdog | 6 | UART | 2 | 8 Channel 8-bit A/D, 2 PWM Outputs,<br>Capture/Compare Timer | | | | PCx | 83C552 (80C552) | 8K | | 256 | 3 + Watchdog | 6 | UART, I2C | 2 | 8 Channel 10-bit A/D, 2 PWM Outputs,<br>Capture/Compare Timer | | | | S | 87C552 | <del> </del> | 8K | 256 | 3 + Watchdog | 6 | UART, I2C | 2 | (see above) | | | Notes: Part number prefixes are noted in the first column. All combinations of part type, speed, temperature and package may not be available. | Part Number | | Program | Clock Freq | (\$4U=) | | | | | Packa | Package | | | | |-------------------|----------|---------------|-------------|------------------------------------|--------|-------------|----------------|------------------------------------------|------------|--------------------------------------------------|------------|--|--| | (ROMIess) | | Security? | (MHz) | 0 to 70 -40 to +85 -55 to +125 | | | PDIP | CDIP | PLCC | CLCC | PQFP/SS | | | | 83C750 | S | N | 3.5 to 40 | Х | X | | N24 | F24 | A28 | <del> </del> | DB24 (0-7 | | | | 87C750 | S | Υ | 3.5 to 40 | Х | Х | | N24 | F24 | A28 | <del> </del> | DB24 (0-7 | | | | 83C748 | S | N | 3.5 to16 | Х | Х | | N24 | | A28 | | DB24 (0-7 | | | | 87C748 | s | Y | 3.5 to16 | Х | Х | | N24 | F24 | A28 | <u> </u> | DB24 (0-7 | | | | 83C751 | S | N | 3.5 to16 | Х | Х | 2.1 | N24 | | A28 | <del> </del> | DB24 (0-7 | | | | 87C751 | S | Υ | 3.5 to16 | X | Х | | N24 | F24 | A28 | <del> </del> | DB24 (0-7) | | | | 83C749 | S | N | 3.5 to 16 | Х | Х | | N28 | | A28 | | DB28 (0-7 | | | | 87C749 | S | Υ | 3.5 to 16 | х | х | | N28 | F28 | A28 | | DB28 (0-7 | | | | 83C752 | S | N | 3.5 to 16 | Х | Х | x | N28 | | A28 | | DB28 (0-7 | | | | 87C752 | S | Υ . | 3.5 to 16 | Х | Х | x | N28 | F28 | A28 | | DB28 (0-7 | | | | 8051AH (8031AH) | S | N | 3.5 to 15 | X | × | | N40 | | A44 | | DD20 (0=7 | | | | SC80C51 (80C31) | s | Υ | 3.5 to 33 | х | X | × | N40 | | A44 | | | | | | PCx80C51 (80C31) | Н | N | 1.2 to 30 | X | X | × | P (40) | | | | B44 (5) | | | | 87C51 | s | Υ | 3.5to 33 | X | X | × | N40 | F40 | WP (44) | K44 | H (44) | | | | 80CL51 (80CL31) | z | N | 0 to 16 (1) | | X | | N40 (2) | F4U | A44 | N44 | B44 (5) | | | | 83CL410(80CL410) | Z | N | 0 to 12 (1) | | X | | N40 (2) | | <u> </u> | | B44 | | | | 83C451 (80C451) | s | N | 3.5 to 16 | х | X | х | | | 1 | | B44 | | | | 87C451 | s | Υ | 3.5 to 16 | X | X | X | N64 (4) | | A68 | 2.5 | | | | | 83C550 (80C550) | s | Y | 3.5 to 16 | X | X | | N64 (4)<br>N40 | | A68 | | | | | | 87C550 | S | Y | 3.5 to 16 | X | X | -40 to +125 | | F40 | A44 | | | | | | 83C851 (80C851) | Н | Y | 1.2 to 16 | X | X | -40 to +125 | N40 | F40 | A44 | K44 | | | | | 83C542 | s | Y | 3.5 to 16 | X | _ ^ | | N40 | | A44 | | B44 | | | | 87C542 | s | Y . | 3.5 to 16 | × | | | | | A44 | | | | | | 83C852 | H | · · | 1 to 12 | X | | | | | A44 | K44 | | | | | 000002 | П | | 1 10 12 | Χ | | | SO28<br>or die | | | | | | | | 83CL580 (80CL580) | z | N | 0 to 12 (1) | | Х | | (3) | | - | 1 - 1 | | | | | | | | | | | | (0) | | | | B64 | | | | 8052AH (8032AH) | S | Ν | 3.5 to 15 | Х | Х | | N40 | | A44 | | | | | | 80C52 (80C32) | s | Y | 3.5 to 24 | X | Х | | N40 | | A44 | | B44 (5) | | | | 87C52 | s | Υ Υ | 3.5 to 24 | Х | Х | x | N40 | F40 | A44 | K44 | B44 (5) | | | | 83C652 (80C652) | н | Υ | 1.2 to 24 | Х | Х | -40 to +125 | N40 | | A44 | | B44 | | | | 87C652 | s | 875 Y 88 Y 88 | 1.2 to 20 | Х | Х | X | N40 | F40 | A44 | K44 | D44 | | | | 83C453 (80C453) | S | N | 3.5 to 16 | Х | X | | | | A68 | 1144 | | | | | 87C453 | s | Υ | 3.5 to16 | Х | х | | | | A68 | | | | | | 83C51FA (80C51FA) | s | Υ | 3.5 to 24 | Х | х | | N40 | | A44 | | B44 | | | | 87C51FA | S | Υ | 3.5 to 24 | х | х | | N40 | F40 | A44 | K44 | B44 | | | | 83L51FA | s | Υ | 3.5 to 20 | x | Х | | N40 | 140 | A44<br>A44 | N44 | B44<br>B44 | | | | 87L51FA | s | Υ | 3.5 to 20 | х | X | | N40 | F40 | A44<br>A44 | 1/44 | | | | | 83C575 (80C575) | s | Υ | 4 to 16 | X | | X | N40 | 1 40 | A44<br>A44 | K44 | B44 | | | | | | | | | e e ve | ^ | 1440 | erie ere ere ere<br>Historiaansk ere ere | A44 | | B44 | | | | 87C575 | S | Y | 4 to 16 | х | | X | N40 | F40 | A44 | K44 | B44 | | | | 83C576 (80C576) | s | Υ | 4 to 16 | х | | X | N40 | | A44 | | B44 | | | | | $\sqcup$ | | *** | | | | 1 | | '''' | | 277 | | | | 87C576 | s | Υ | 4 to 16 | Х | | Х | N40 | F40 | A44 | K44 | B44 | | | | 83C562 (80C562) | Н | N | 1.2 to 16 | Х | Х | -40 to +125 | | | A68 | | B80 | | | | 83C552 (80C552) | Н | N | 1.2 to 30 | Х | Х | -40 to +125 | | | A68 | | B80 | | | | 87C552 | s | Y | 1.2 to 16 | X | | | | | A68 | K68 | | | | Notes: Production Centers are indicated in the second column: H – Hamburg, S – Sunnyvale, Z – Zurich. All combinations of part type, speed, temperature and package may not be available. 1) Oscillator options start from 32kHz. 2) Also available in VSO40 package. 3) Also available in VSO56 Package. 4) Not recommended for new design. 5) Package available up to 16 MHz only. | | Part Number | | Memory | | | 1/0 | Serial | External | Comments/ | | |----------|----------------------------------------|--------------|--------|------|--------------|-------|----------------------------|--------------|------------------------------------------------------------------------------|--| | | (ROMiess) | ROM | EPRM | RAM | Timers | Port | Interfaces | Interrupt | Special Features | | | · T | 83CL267 | 12K | | 256 | 3 | 2 5/8 | I <sup>2</sup> C | <del>-</del> | OSD, 8 PWM Outputs, 3 Software A/D Inputs,<br>8 LED Drivers | | | , + | 83CL268 | 12K | | 256 | 3 | 2 5/8 | I <sup>2</sup> C, 1M Baud | | (see above) | | | + | 83C055 | 16K | | 256 | 2 (16-bit) | 3 1/2 | <del>-</del> | 2 | On-Screen Display, 9 PWM Outputs,<br>3 Software A/D Inputs | | | 5 | 87C055 | | 16K | 256 | 2 (16-bit) | 3 1/2 | | 2 | (see above) | | | | | 16K | 101 | 256 | 3 | 4 | UART | 2 | Standard; 80C51 compatible | | | `\ | 80C54 | 101 | 16K | 256 | 3 | 4 | UART | 2 | Standard; 87C51 compatible | | | `\ | 87C54 | 16K | 101 | 256 | 2 | 4 | UART | 2 | '654 with Hardware Divide (no I <sup>2</sup> C) | | | <u> </u> | 83C504 (80C504) | 100 | 16K | 256 | 2 | 4 | UART | 2 | (see above) | | | P | 87C504 | 16K | 101 | 256 | 2 | 4 | UART, I <sup>2</sup> C | 2 | 80C51 Pin Compatible | | | P | 83C654 | 101 | | 250 | - | | | | | | | s | 87C654 | | 16K | 256 | 2 | 4 | UART, I <sup>2</sup> C | 2 | (see above) | | | P + | 83CE654 | 16K | | 256 | 2 | 4 | UART, I <sup>2</sup> C | 2 | 83C654 with Reduced EMI | | | P | 83CL781 | 16K | | 256 | 3 | 4 | UART, I <sup>2</sup> C | 10 | Low Voltage (1.8V to 6V), Low Power | | | P | 83CL782 | 16K | | 256 | 3 | 4 | UART, I <sup>2</sup> C | 10 | 83CL781 Optimized 12MHz @ 3.1V | | | s | 83C51FB | 16K | - | 256 | 3 + PCA | 4 | UART | 2 | Enhanced UART, 3 timers + PCA | | | s | 87C51FB | | 16K | 256 | 3 + PCA | 4 | UART | 2 | Enhanced UART, 3 timers + PCA | | | s | 83L51FB | 16K | + | 256 | 3 + PCA | 4 | UART | 2 | Low Voltage 83C51FB (3V @ 20MHz) | | | s | 87L51FB | 1.511 | 16K | 256 | 3 + PCA | 4 | UART | 2 | Low Voltage OTP 87C51FB (3V @ 20MHz | | | P | 83CL167 | 16K | | 256 | 3 | 6 1/8 | I <sup>2</sup> C | * - · | OSD, 8 PWM Outputs,<br>4 Software A/D Inputs, 8 LED Drivers | | | P | 83CL168 | 16K | - | 256 | 3 | 6 1/8 | I <sup>2</sup> C, 1M Baud | - | (see above) | | | P | 83C524 | 16K | + | 512 | 3 + Watchdog | 4 | UART, I <sup>2</sup> C-bit | 2 | 512 RAM | | | P | 87C524 | 1000 | 16K | 512 | 3 + Watchdog | 4 | UART, I <sup>2</sup> C-bit | 2 | 512 RAM | | | P | 83C592 (80C592) | 16K | 1 | 512 | 3 + Watchdog | 6 | UART, CAN | 6 | CAN Bus Controller with 8 x 10-bit A/D, 2 PWM outputs, Capture/Compare Timer | | | P | 87C592 | <del> </del> | 16K | 512 | 3 + Watchdog | 6 | UART, CAN | 6 | (see above) | | | | | 32K | 1010 | 256 | 3 | 4 | UART | 2 | Standard; 80C51 compatible | | | Р | 80C58<br>87C58 | 32N | 32K | 256 | 3 | 4 | UART | 2 | Standard; 87C51 compatible | | | Р | | 32K | 321 | 256 | 3 + PCA | 4 | UART | 2 | Enhanced UART, 3 timers + PCA | | | S | 83C51FC | 32N | 32K | 256 | 3 + PCA | 4 | UART | 2 | Enhanced UART, 3 timers + PCA | | | s | 87C51FC | | 32N | 512 | 3 + Watchdog | 4 | UART, I <sup>2</sup> C-bit | | Large Memory for High Level Languages | | | P | 83C528 (80C528) | 32K | 32K | 512 | 3 + Watchdog | 1 4 | UART, I <sup>2</sup> C-bit | | Large Memory for High Level Languages | | | Р | 87C528 | - 001/ | | 512 | 3 + Watchdog | 4 | UART, I <sup>2</sup> C-bit | | 8XC528 with Reduced EMI | | | P<br>P | 83CE528 (80CE528)<br>83CE598 (80CE598) | 32K<br>32K | | 512 | 3 + Watchdog | 6 | UART, CAN | 6 | CAN Bus Controller, 8 x 10-bit A/D,<br>2 PWM outputs, WD, T2, Reduced EMI | | | | | _ | 32K | 512 | 3 + Watchdog | 6 | UART, CAN | 6 | (see above) | | | P<br>P | 87CE598<br>83CE558(80CE558) | 32K | | 1024 | 3 + Watchdog | 6 | UART, I <sup>2</sup> C | 2 | Low EMI, 8 Channel 10-bit A/D,<br>2 PWM Outputs, Capture/Compare Time | | | | | 1 | 32K | 1024 | 3 + Watchdog | 6 | UART, I <sup>2</sup> C | 2 | 32K FLash EEPROM plus above | | Notes: Part number prefixes are noted in the first column. All combinations of part type, speed, temperature and package may not be available. | Part Number | | Program | Clock Freq | Temperature Ranges (°C) | | | Package | | | | | |-------------------|------|-----------|-------------|-------------------------|------------|-------------|--------------------------------------------------|--------------------------------------------------|-----------|----------|-----------| | (ROMIess) | 1.14 | Security? | (MHz) | 0 to 70 | -40 to +85 | -55 to +125 | PDIP | CDIP | PLCC | CLCC | PQFP/SSOI | | 83CL267 | Т | N | 4.0 to 12 | Х | | | R42 | | | | B64 | | 83CL268 | Т | N | 4.0 to 12 | х | | | R42 | | 1 | 1 | B64 | | 83C055 | S | N | 3.5 to 20 | × | | | NB42 | | | | | | 87C055 | s | N | 3.5 to 20 | х | <b>†</b> | | NB42 | - | | | | | 80C54 | s | Υ | 3.5 to 24 | х | X | | N40 | <b>-</b> | A44 | 205 | B44 | | 87C54 | s | Y | 3.5 to 24 | X | X | | N40 | F40 | A44 | K44 | B44 | | 83C504 (80C504) | s | Υ | 1.2 to 20 | X | X | × | N40 | | A44 | | B44 | | 87C504 | s | Υ | 1.2 to 20 | X | X | х | N40 | F40 | A44 | K44 | B44 | | 83C654 (80C654) | Н | Υ | 1.2 to 24 | X | X | -40 to +125 | R42,<br>N40 | | A44 | | B44 | | 87C654 | s | Y | 1.2 to 20 | X | X | х | N40 | F40 | A44 | K44 | B44 | | 83CE654 | Н | Υ | 1.2 to 16 | Х | Х | | | | | | B44 | | 83CL781 | z | N | 0 to 12 (1) | | Х | | N40 | | | | B44 | | 83CL782 | z | N | 0 to 12 (1) | | -25 to +55 | | N40 | | 1 1 1 4 7 | 1 | B44 | | 83C51FB | s | Υ | 3.5 to 24 | Х | х | | N40 | | A44 | | B44 | | 87C51FB | s | Υ | 3.5 to 24 | Х | Х | | N40 | F40 | A44 | K44 | B44 | | 83L51FB | s | Υ | 3.5 to 20 | X | | | N40 | | A44 | | B44 | | 87L51FB | s | Υ | 3.5 to 20 | х | | | N40 | F40 | A44 | K44 | B44 | | 83CL167 | Т | N | 4.0 to 12 | х | | | R42 | | | | B64 | | 83CL168 | T | N | 4.0 to 12 | Х | | | R42 | | | 1 | B64 | | 83C524 | Н | Υ | 1.2 to 16 | Х | Х | | N40 | | A44 | | B44 | | 87C524 | s | Y | 3.5 to 20 | х | Х | | N40 | F40 | A44 | K44 | B44 | | 83C592 (80C592) | Н | Υ | 1.2 to 16 | | х | -40 to +125 | | | A68 | K68 | | | 87C592 | Н | Υ | 1.2 to 16 | X | | | R42 | | A68 | K68 | <u> </u> | | 80C58 | s | Y | 3.5 to 16 | Х | Х | | N40 | | A44 | | B44 | | 87C58 | s | Υ γ | 3.5 to 16 | Х | x | | N40 | F40 | A44 | K44 | B44 | | 83C51FC | s | . Y | 3.5 to 24 | х | X | | N40 | | A44 | 1 3 | B44 | | 87C51FC | s | Υ | 3.5 to 24 | х | X | | N40 | F40 | A44 | K44 | B44 | | 83C528 (80C528) | Н | Υ | 1.2 to 16 | Х | х | -40 to +125 | N40 | 1 | A44 | 1 | B44 | | 87C528 | s | Y | 3.5 to 20 | X | × | | N40 | F40 | A44 | K44 | B44 | | 83CE528 (80CE528) | Н | Υ | 1.2 to 16 | Х | X | -40 to +125 | | 1 | A44 | <b>†</b> | B44 | | 83CE598 (80CE598) | Н | Y | 1.2 to 16 | | х | -40 to +125 | | <u> </u> | 1 | | B80 | | 87CE598 | Н | Υ | 3.5 to 16 | Х | x | | l | | - | | B80 | | 83CE558 80CE558 | Н | Y | 1.2 to 16 | Х | х | -40 to +125 | | | | | B80 | | 89CE558 | Н | Y | 1.2 to 16 | Х | X | | <del> </del> | <del> </del> | 1 | Q80 | B80 | Notes: Production Centers are indicated in the second column: H – Hamburg, S – Sunnyvale, Z – Zurich. All combinations of part type, speed, temperature and package may not be available. 1) Oscillator options start from 32kHz. 2) Also available in VSO40 package. 3) Also available in VSO56 Package. 4) Not recommended for new design. 5) Package available up to 16 MHz only. # 8051 microcontroller cross-reference guide | To go w | INTEL | SIEMENS | ОКІ | MATRA/HARRIS | PHILIPS SEMICONDUCTORS | |--------------|------------|------------|----------|--------------|-------------------------| | CMOS | 80C31BH | SAB 80C31 | MSM80C31 | 80C31 | PCB80C31BH-2/SC80C31BCC | | | 80C31BH-1 | | | 80C31-1 | PCB80C31BH-3/SC80C31BCG | | | 80C31BH-2 | | MSM80C31 | 80C3151 | /SC80C31BCB | | and a second | 000012.1.2 | The second | | | | | | 80C51BH | SAB 80C51 | MSM80C51 | 80C51 | PCB80C51BH-2/SC80C51BCC | | | 80C51BH-1 | 2.1.2 | | 80C51-1 | PCB80C51BH-3/SC80C51BCG | | | 80C51BH-2 | | MSM80C51 | 80C51 | /SC80C51BCB | | | | | | | | | | 87C51 | | | | SC87C51CC | | | 87C51-1 | | | | SC87C51CG | | | 87C51-2 | | | | SC87C51CB | | | 87031-2 | | | | 000700102 | | | 80C32 | SAB80C32 | | | P80C32EB | | | 80C32-1 | OADOUGE. | | 80C32-25 | P80C32GB | | | 80C52 | SAB80C52 | | 00002 20 | P80C52EB | | | 80C52-1 | GADOUGS2 | | 80C52-25 | P80C52GB | | | 80032-1 | | | 00032-23 | 1,0000200 | | | 80C54 | | | | 80C54 | | | 83C54 | | | | 83C54 | | | 87C54 | | | | 87C54 | | | 80C58 | | | | 80C58 | | | 83C58 | | | | 83C58 | | | 87C58 | | | | 87C58 | | | | | | | | | CMOS | 83C51FA | W | | | S83C51FA | | ONICO | 87C51FA | 19 9 6 | | · 1 | S87C51FA | | | 83C51FB | | | | S83C51FB | | | 87C51FB | | | | S87C51FB | | | 83C51FC | | | | S83C51FC | | | 87C51FC | | | 13.00 | S87C51FC | | | l 6/05/FC | 1 | | | 307031F0 | NOTES: 1. 80XXAHL = 80XX with low power standby pin; H = HMOS. # Low power / low voltage microcontroller family #### **80C51 LOW POWER FAMILY** | Type | Available | ROM | RAM | 1/0 | I <sup>2</sup> C | UART | Features | Package | |---------|-----------|----------------|-----|-----|------------------|------|----------------------------------|---------------------------------------------------------------------------| | 80CL51 | Yes | 4k | 128 | 32 | No | Yes | Low Voltage 80C51 | 40-Pin Dual In-Line<br>40-Pin Very Small Outline<br>44-Pin Quad Flat Pack | | 80CL31 | Yes | | 128 | 32 | No | Yes | Low Voltage 80C31 | 40-Pin Dual In-Line<br>40-Pin Very Small Outline<br>44-Pin Quad Flat Pack | | 83CL410 | Yes | 4k | 128 | 32 | Yes | No | 80CL51 with I <sup>2</sup> C-bus | 40-Pin Dual In-Line<br>40-Pin Very Small Outline<br>44-Pin Quad Flat Pack | | 80CL410 | Yes | <del>-</del> | 128 | 32 | Yes | No | 80CL51 with I <sup>2</sup> C-bus | 40-Pin Dual In-Line<br>40-Pin Very Small Outline<br>44-Pin Quad Flat Pack | | 83CL580 | Yes | 6k | 256 | 40 | Yes | Yes | ADC, PWM, Watchdog, T2 | 50-Pin Very Small Outline<br>64-Pin Quad Flat Pack | | 80CL580 | Yes | | 256 | 40 | Yes | Yes | ADC, PWM, Watchdog, T2 | 50-Pin Very Small Outline<br>64-Pin Quad Flat Pack | | 83CL781 | Yes | 16k | 256 | 32 | Yes | Yes | Low voltage 83C654, T2 | 40-Pin Dual In-Line<br>44-Pin Quad Flat Pack | | 83CL782 | Yes | 16k | 256 | 32 | Yes | Yes | Fast 83CL781: 12MHz/3V | 40-Pin Dual In-Line<br>44-Pin Quad Flat Pack | | 85CL000 | Yes | ; <del>-</del> | 256 | 32 | Yes | Yes | For SW development | Piggyback | | 85CL580 | Yes | - | 256 | 40 | Yes | Yes | For SW development | Piggyback | | 85CL782 | Yes | _ | 256 | 32 | Yes | Yes | For SW development | Piggyback | #### **LOW VOLTAGE DEVICES** | Туре | Available | ROM | RAM | I/O | I <sup>2</sup> C | UART | Features | Package | |---------|-----------|----------------------|-----|-----|------------------|------|------------------------------------|-------------------------------------------------------------| | 83L51FA | Yes | 8k | 256 | 32 | No | Yes | PCA, Enhanced UART<br>3.0V to 4.5V | 40-Pin Dual In-Line<br>44-Pin PLCC<br>44-Pin Quad Flat Pack | | 87L51FA | Yes | 8k<br>EPROM/<br>OTP | 256 | 32 | No | Yes | PCA, Enhanced UART<br>3.0V to 4.5V | 40-Pin Dual In-Line<br>44-Pin PLCC<br>44-Pin Quad Flat Pack | | 83L51FB | Yes | 16k | 256 | 32 | No | Yes | PCA, Enhanced UART<br>3.0V to 4.5V | 40-Pin Dual In-Line<br>44-Pin PLCC<br>44-Pin Quad Flat Pack | | 83L51FB | Yes | 16k<br>EPROM/<br>OTP | 256 | 32 | No | Yes | PCA, Enhanced UART<br>3.0V to 4.5V | 40-Pin Dual In-Line<br>44-Pin PLCC<br>44-Pin Quad Flat Pack | # 80C51 microcontroller development system support ## **DEVELOPMENT SYSTEM CONTACTS** | COMPANY | ADDRESS | TELEPHONE | |------------------------------|-------------------------------------------------------------------------------|------------------| | Ashling Microsystems Limited | Plassey Technological Park<br>Limerick, Ireland | (353) 61 334 466 | | | Eastern Systems Inc.<br>160 East Main Street<br>Westboro, MA 01581 | (508) 366-3220 | | BSO Tasking | Norfolk Place<br>333 Elm Street<br>Dedham, MA 02026-4530 | (800) 458-8276 | | Ceibo Ltd. | 105 Gleason Rd.<br>Lexington, MA 02173 | (617) 863-9927 | | | Merkazim Building, Industrial Zone<br>P.O. Box 2106<br>Herzelia 46120, ISRAEL | 972-52-555387 | | Lauterbach Datentechnik GmbH | Fichtenstrasse 27<br>85649 Hofolding<br>Germany | 49 8104 894 328 | | | 945 Concord Street<br>Framingham, MA 01701 | (508) 620-4521 | | MetaLink Corp. | 325 E. Elliot Road, Suite 23<br>Chandler, AZ 85225 | (602) 926–0797 | | Nohau Corp. | 51 E. Campbell Ave.<br>Campbell, CA 95008-2053 | (408) 866–1820 | | Philips Semiconductors | Corporate Centre<br>Building BAE-2<br>P.O. Box 218<br>5600 MD Eindhoven | 31-40-724223 | | SIGNUM Systems | The Netherlands 171 E. Thousand Oaks Blvd., #202 Thousand Oaks, CA 91360 | (805) 371-4608 | ## **EPROM PROGRAMMING SUPPORT CONTACTS** | Advin Systems<br>1050-L East Duane Ave.<br>Sunnyvale, CA 94086<br>(408) 736-2503 | Logical Devices, Inc.<br>1201 Northwest 65th Place<br>Ft. Lauderdale, FL 33309<br>(305) 974-0967 | North Valley Products<br>P.O. Box 32899<br>San Jose, CA 95152<br>(408) 929-5345 | |---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | BP Microsystems<br>10681 Haddington #190<br>Houston, TX 77043<br>(800) 225-2102, (713) 461-9430 | Logical Systems P. O. Box 6184 Syracuse, NY 13217-6184 (315) 478-0722 | Strebor Data Communications<br>1008 N. Nob Hill<br>American Fork, UT 84003<br>(801) 756-3605 | | Data I/O Corp.<br>10525 Willows Road N.E.<br>P.O. Box 97046<br>Redmond, WA 98073-9746<br>(206) 881-6444 | Needham's Electronics<br>4535 Orange Grove Ave.<br>Sacramento, CA 95841<br>(916) 924-8037 | | # 80C51 microcontroller development system support ### **SOFTWARE SUPPORT CONTACTS** | COMPANY | ADDRESS | TELEPHONE | | | |---------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--|--| | Archimedes Software, Inc. | 2159 Union St.<br>San Francisco, CA 94123 | (415) 567–4010 | | | | BSO/Tasking | Tasking Software BV<br>P.O. Box 899<br>3800 AW Amersfoort<br>The Netherlands | 31-33-55-85-84 (Telephone)<br>31-33-55-00-33 (Fax) | | | | | BSO Tasking<br>128 Technology Center<br>P.O. Box 9164<br>Waltham, MA 02254-9164 | (617) 894-7800 (Telephone)<br>(617) 894-0551 (Fax)<br>(710) 324-0760 (Telex)<br>(800) 458-8276 (Toll Free) | | | | Franklin Software, Inc. | 888 Saratoga Ave. #2<br>San Jose, CA 95129 | (408) 296–8051 | | | | Keil Software | Bretonischer Ring 15<br>85630 Grasbrunn<br>Germany | 49-89-46-50-57 (Telephone)<br>49-89-46-81-62 (Fax) | | | #### NOTE: For more information on Development Support, see Section 9, Vol. 2, IC20. # 8-bit microcontroller demonstration and evaluation boards | PRODUCT | DESCRIPTION | |---------------------|-----------------------------------------------------------------| | OM4151, S87C00K | I <sup>2</sup> C demonstration board based on 80C51 derivatives | | | | | OM4238, P8051DB | 8051 family demonstration board | | OM4128 | 8XC552 evaluation board PEB552 | | OM4130, PCAN-EVAL | CAN controller evaluation board | | OM4239 | 8XC592 evaluation board PEB592 | | OM4240 | 8XCE598 evaluation board PEB598 | | OM4241 | 8XCE598 evaluation board PDB598 | | | | | OM4160, SM68070 | 68070 and 66470 demonstration and evaluation board Microcore 1 | | OM4160/2 | 68070 evaluation board Microcore 2 | | OM4162 | 9XCE201 evaluation board Microcore 4 | | | | | OM4280, P83C852DEM | 83C852 demonstration kit | | OM4281 <sup>1</sup> | 83C852 software evaluation kit | | P8051DB | 80C51 family development board | | OM4717 | 83CL410 solar powered demonstration board | | OM5005, P80CLEVAL | 80CL51 evaluation board | | | | | DS750 | 8XC750 microcontroller in-circuit emulation development tool | #### NOTE: <sup>1.</sup> The OM4281 is now available only from Ashling Microsystems Ltd. as type SCPC4281. #### Microcontroller bulletin boards To better serve our customers, Philips maintains two microcontroller bulletin boards. These computer bulletin board systems feature microcontroller newsletters, application and demonstration programs for download, and the ability to send messages to microcontroller application engineers. The telephone numbers are: North American Bulletin Board 300/1200/2400 baud 8-N-1 (800) 451-6644 (in the U.S.) or (408) 991-2406 European Bulletin Board MAX 14.400 baud Standards V32/V42/V42.bis/HST +31 40 721102 European Application Help Desk +31 40 722749 9a.m. – 16p.m. CET (Central European Time) ## Sunnyvale ROMcode Bulletin Board We also have a ROM code bulletin board through which you can submit ROM codes. This is a closed bulletin board for security reasons. To get an ID, contact your local sales office. The system can be accessed with a 2400, 1200, or 300 baud modem, and is available 24 hours a day. The telephone number is: (408) 991-3459 The following application note files are available on the Philips BBS: | App Note | BBS file name | App Note | BBS file name | Articles: | |----------|---------------|-------------|---------------|---------------------------------------| | AN417 | PRN256K.ZIP | AN434 | I2CPCKB.ZIP | Add text overlay to any video display | | AN420 | INTRUPTS.ASM | AN435 | IIC_OS.ZIP | CCI6.ZIP, MTV.ZIP | | AN422 | I2CAPP.ZIP | AN438 | 12C528.EXE | | | AN423 | RS751.ASM | AN439 | BATTCHRG.C | | | AN424 | WARMBOOT.ZIP | AN440 | BOOTSTRP.ZIP | | | AN425 | 12C8584.ZIP | AN443 | MAZEMOUS.ZIP | | | AN427 | TIMERI.ZIP | AN445 | ABMOUSE.ZIP | | | AN428 | DEMO752.ASM | AN446 | DUPUART.ZIP | | | AN429 | AN429.ZIP | AN447 | AUTOBAUD.ZIP | | | AN430 | MM751.ZIP | EIE/AN91007 | MM751B.ZIP | | | AN433 | SLV751.ZIP | EIE/AN91009 | EEPRM851.ZIP | | | | | | | | ## **Philips Fax-On-Demand System** #### What's the number? 1-800-282-2000 #### What is it? The Fax-On-Demand system is a computer facsimile system that allows customers to receive selected documents by Fax automatically. Philips Fax-On-Demand system is now set up to fax selected datasheets as customers request them, 24 hours per day, 7 days per week. #### How does it work? Each time the system receives a call, the voice card plays the pre-recorded messages, and waits for the caller's responses. Based on the caller's responses, the system will find and fax the appropriate document to the caller's fax machine. To receive a document, the user must know the document number. This number can be obtained by asking for an index of available documents the first time that he/she calls the system. #### How is it set up? The Philips Fax-On-Demand system has six indexes (so far): - 1. Communication - 2. Audio & Video (in progress) - 3. Microcontrollers - 4. Logic - 5. Linear - 6. PLD So far, the system has 600 data sheets. We expect this number to rise to 800 data sheets very soon and keep increasing every quarter. As you know, it will take approximately one minute to fax one page. This wouldn't be that bad if the number of pages is less than ten. But if the document is 37 pages long, be ready for a long transmission!!! Philips Fax-On-Demand number is 1-800-282-2000, try it! The following listing of products are those for which documents are available via "Fax-On-Demand" for the communications category. 24 Coming soon: Fax-On-Demand for our European-produced products. #### Who do I contact if I have any questions about Fax-On-Demand? Hamid Mohammadi Phone: (408) 991-4895 Technical Support Center # 80C51 FAMILY CMOS | TYPE | ROM/<br>EPROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PHILIPS<br>PROBES | THIRD PARTY | |-----------------------------------------|--------------------------------|--------------------------|------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------|-----------------------------| | 80C31<br>80C51<br>87C51 | 0<br>4k ROM<br>4k EPROM | 128<br>128<br>128 | 33<br>33<br>33 | DIL40, LCC44<br>QFP44 | UART, 2 timers | 87C51:QFP<br>package up to<br>16MHz | OM1092<br>+ OM1097<br>(16MHz)<br>OM4120S | 8052PC(M)<br>POD-C51B(N) | | 83C51FA<br>87C51FA | 8k ROM<br>8k EPROM | 256<br>256 | 24<br>24 | DIL40, LCC44<br>QFP44 | Enhanced UART, 3 timers, PCA | | PDS51FBSD | 8351FX(M)<br>POD-C51FX(N) | | 83L51FA<br>87L51FA | 8k ROM<br>8k EPROM | 256<br>256 | 20<br>20 | DIL40, LCC44<br>QFP44 | Enhanced UART, 3 timers,<br>PCA | 3V to 4.5V operation | | POD-L51P(N) | | 87C51FB<br>83C51FB | 16k ROM<br>16k EPROM | 256<br>256 | 24<br>24 | DIL40, LCC44<br>QFP44 | Enhanced UART, 3 timers, PCA | | PDS51FBSD | 8351FX(M)<br>POD-C51FX(N) | | 87L51FB<br>83L51FB | 16k ROM<br>16k EPROM | 256<br>256 | 20<br>20 | DIL40, LCC44<br>QFP44 | Enhanced UART, 3 timers, PCA | 3V to 4.5V operation | | POD-L51P(N) | | 87C51FC<br>83C51FC | 32k ROM<br>32k EPROM | 256<br>256 | 24<br>24 | DIL40, LCC44<br>QFP44 | Enhanced UART, 3 timers, PCA | | | 8351FX(M)<br>POD-C51FX(N) | | 80C32<br>80C52<br>87C52 | 0<br>8k ROM<br>8k EPROM | 256<br>256<br>256 | 24<br>24<br>24 | DIL40, LCC44<br>QFP44 | UART, 3 timers | | OM1079<br>OM5012 | 8052PC(M)<br>POD-C32(N) | | 80C54<br>87C54 | 16k ROM<br>16k EPROM | 256<br>256 | 24<br>24 | DIL40, LCC44<br>QFP44 | UART, 3 timers | | OM1079<br>OM5012 | 8052PC(M)<br>POD-C32(N) | | 80C58<br>87C58 | 32k ROM<br>32k EPROM | 256<br>256 | 24<br>24 | DIL40, LCC44<br>QFP44 | UART, 3 timers | | OM1079<br>OM5012 | 8052PC(M)<br>POD-C32(N) | | 80C451<br>83C451<br>87C451 | 0<br>4k ROM<br>4k EPROM | 128<br>128<br>128 | 16<br>16<br>16 | DIP64/LCC68 | UART, 2 timers<br>Extended I/O | | OM4123 | 83C451PC(M)<br>POD-C451B(N) | | 83C504<br>87C504 | 16K ROM<br>16K EPROM | 256<br>256 | 24<br>24 | DIL40, LCC44<br>QFP44 | 24 by 8 divide,<br>2 timers | | W | | | 87C524<br>83C524 | 16K EPROM<br>16k ROM | 512<br>512 | 20<br>12 | DIL40/LCC44<br>QFP44 | UART, 3 timers<br>Watchdog timer<br>Bit I <sup>2</sup> C | | OM4111 +<br>OM4110 +<br>OM4120S | 83528PC(M)<br>POD-C528(N) | | 83C528<br>87C528<br>83CE528 | 32k ROM<br>32k EPROM<br>32kROM | 512<br>512 | 16<br>16, 20 | DIL40/LCC44<br>(QFP44) | UART, 3 timers<br>Watchdog timer<br>Bit I <sup>2</sup> C | | OM4111 +<br>OM4110 +<br>OM4120S | 83C528PC(M)<br>POD-C528(N) | | 80C550<br>83C550<br>87C550 | 0<br>4k ROM<br>4k EPROM | 512<br>128<br>128<br>128 | 16<br>16<br>16<br>16 | CE ONLY QFP<br>LCC44<br>DIL40 | UART, 2 timers<br>8 8-bit ADC inputs, watchdog<br>timer | | OM5055 +<br>OM4110 | 83550(M)<br>POD-C550(N) | | 80C552<br>83C552<br>87C552 | 0<br>8k ROM<br>8k EPROM | 256<br>256<br>256 | 16, 24<br>16, 24<br>16 | LCC68/QFP80 | UART, 2 timers<br>Timer with compare and cap-<br>ture, 2 PWM outputs, 8 10-bit<br>ADC inputs, Byte I2C | | OM1092 +<br>OM1095 +<br>OM4120S<br>OM4128 | 83C552PC(M)<br>POD-C552B(N) | | 83CE558<br>89CE558<br>80CE558 | 32K ROM<br>32K FLASH<br>0 | 1K<br>1K | 16<br>16 | QFP80 | As 8xC552 with<br>PLL-oscillator<br>Auto scan ADC | 89C: Q4-92<br>83C: Q2/3-93 | OM4247 | | | 80C562<br>83C562 | 0<br>8k ROM | 256<br>256 | 16<br>16 | LCC68/QFP80 | UART, 2 timers<br>Timer with compare and<br>capture, 2 PWM outputs, 8<br>8-bit ADC inputs | | OM1092 +<br>OM1095 +<br>OM4120S | 83C552PC(M)<br>POD-C552B(N) | | 30C575<br>33C575<br>37C575 | 0<br>8k<br>8k EPROM | 256<br>256<br>256 | 16<br>16<br>16 | DIL40, LCC44<br>QFP44 | 3 timers 1<br>Enh. UART, PCA, 4 analog<br>comparators | | | POD-C575(N) | | 33C576<br>37C576 | 8k ROM<br>8k EPROM | 256<br>256 | 16<br>16 | DIL40, LCC44,<br>SDIL42 | 10-bit A/D, 3 timers, PCA,<br>Watchdog timer | | | | | 80C592<br>83C592<br>87C592<br>M = Metli | 0<br>16k ROM<br>16k EPROM | 512<br>512<br>512 | 16<br>16<br>16 | LCC68/QFP80 | 8XC552 + CAN interface | | OM4110 +<br>OM4112 +<br>OM4120S | POD-592(N) | N = Nohau ## 80C51 FAMILY CMOS (Continued) | TYPE | ROM/<br>EPROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PHILIPS<br>PROBES | THIRD PARTY<br>PODs | |-------------------------------|---------------------------|-------------------|----------------------------|---------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|---------------------------| | 87CE598<br>87CE598<br>80CE598 | 32K ROM<br>32K EPROM<br>0 | 512<br>512<br>512 | 16<br>16<br>16 | QFP80 | 8xC552 + CAN<br>interface.<br>No I <sup>2</sup> C | 87CE:<br>prod: Q2'94 | | | | 80C652<br>83C652<br>87C652 | 0<br>8k ROM<br>8k EPROM | 256<br>256<br>256 | 16, 24<br>16, 24<br>16, 20 | DIL40/LCC44<br>QFP44 | UART, 2 timers<br>Byte I <sup>2</sup> C | | OM1092 +<br>OM1096 +<br>OM4120S | 83652PC(M)<br>POD-C51B(N) | | 83C654<br>87C654 | 16k ROM<br>16k EPROM | 256<br>256 | 16,24<br>16,20 | DIL40/LCC44<br>QFP44 | UART, 2 timers<br>Byte I <sup>2</sup> C | | OM1092 +<br>OM1096 +<br>OM4120S | 83654(M)<br>POD-C51B(N) | | 83CE654<br>80CE654 | 16k ROM<br>0 | 256<br>256 | 16<br>16 | QFP44 | UART, 2 timers<br>Byte I <sup>2</sup> C | 83C654 with<br>Electromagnetic<br>Compatibility<br>improvements | OM1092 +<br>OM1096 +<br>OM4120S | 83654(M)<br>POD-C51B(N) | | 83C750<br>87C750 | 1K ROM<br>1KEPROM | 64<br>64 | 40<br>40 | SDIP24 skinny | 1 timer | | OM1094 | 83751PC(M) | | 83C751<br>83C748<br>87C751 | 2k ROM<br>2k EPROM | 64<br>64 | 16<br>16 | DIP24 skinny<br>LCC28<br>DIP24 skinny | 1 timer<br>Bit I <sup>2</sup> C (8XC751 only) | | OM1094P | 83751PC(M)<br>POD-C751(N) | | 87c748<br>83C752<br>83C749 | 2k ROM | 64 | 16 | DIP28, LCC28 | 1 timer,<br>PWM output,<br>5 8-bit ADC inputs, Bit I <sup>2</sup> C | | OM5072 | 83752A(M) | | 87C752<br>87c752 | 2k EPROM | 64 | 16 | DIP 28, LCC28 | (8XC752 only) | e de la companya l | | POD-C752(N) | | 80C851<br>83C851 | 0<br>4k ROM | 128<br>128 | 16<br>16 | DIL40/LCC44<br>QFP44 | UART, 2 timers<br>256 byte | | OM1092 +<br>OM4120S | 80851PC(M)<br>POD-C51(N) | | 83C852 | 6k ROM | 256 | 6 | | 2k byte<br>EEPROM<br>smart card hardware CU | | | | | 83C055<br>87C055 | 16k ROM<br>16k EPROM | 256<br>256 | 12<br>12 | DIP42 Shrunk<br>DIP42 Shrunk | As 8XC053 | In dev. | OM5054 | | The following microcontollers have no external memory access: 8XC751, 8XC752, 8XC053, 87C054, 83C852. M = Metlink N = Nohau # **80CLXXX FAMILY CMOS** | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PROBE<br>SDS | REMARKS | |--------------------|------------|------------|----------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------|------------------------------------------------| | 85CL000 | 0 | 256 | 12 | Piggyback | Piggyback<br>CL410, CL411,<br>CL51, P80C51 | | | | | 85CL580 | 0 | 256 | 12 | Piggyback | Piggyback<br>CL580 | | | | | 85CL781 | · 0 · | 256 | 12 | Piggyback | Piggyback<br>CL781, CL782,<br>CL52 | | | | | 80CL51<br>80CL31 | 4K<br>0 | 128<br>128 | 16<br>16 | DIL40<br>VSO40 | 2 timers, UART | | OM1079 | QFP: OM5020 | | 83CL410<br>80CL410 | 4k<br>0 | 128<br>128 | 12<br>12 | DIL40<br>VSO40 | 2 timers<br>Byte I <sup>2</sup> C | | OM1079 | QFP: OM5020 | | 83CL580 | 6k | 256 | 16 | QFP64/<br>VSO56 | 3timers, UART<br>Watchdog timer<br>Byte I <sup>2</sup> C,<br>1 PWM<br>4*8 bit ADC | | OM1079 +<br>OM5004 | OM1079: Probe<br>base<br>OM5004: Probe<br>adap | | 83CL781<br>83CL782 | 16k<br>16k | 256<br>256 | 12 @<br>4.5V<br>12 @<br>3V | DIL40<br>QFP44 | 3timers, UART<br>Byte I <sup>2</sup> C | | OM1079 +<br>OM5004 +<br>tbd | OM1079: Probe<br>base<br>OM5004: Probe<br>adap | | 83CL167<br>83CL267 | 16K<br>12K | 256<br>256 | 12<br>12 | SDIL64<br>QFP64 | 3timers 1-14 bit PWM 4-6 bit PWM 4-7 bit PWM 4-7 bit PWM 4*4 bit ADC Byte I <sup>2</sup> C 160 char OSD 126 char fonts 4 char sizes Shadow modes ODS PLL osc. 10MHz Blinking | In Dev | OM4840<br>OM1079 | | | 83CL168<br>83CL268 | 16K<br>12K | 256<br>256 | 12<br>12 | SDIL64<br>QFP64 | Stimers 1-14 bit PWM 4-6 bit PWM 4-7 bit PWM 4-7 bit PWM 4-7 bit ADC RC preprocessor Byte 2C 3 wire serial I/O 160 char OSD 126 char fonts 4 char sizes Shadow modes ODS PLL osc. 10MHz Blinking | In Dev | OM4840 +<br>OM1079 | | #### **8051 FAMILY NMOS** | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PROBE<br>SDS | THIRD PARTY<br>EMULATOR | |--------------|---------|------------|----------------|------------------------------|----------------------------------|---------|---------------------------------|--------------------------| | 8051<br>8031 | 4k<br>0 | 128<br>128 | 15<br>15 | DIL40/PLCC44<br>DIL40/PLCC44 | UART, 2 timers | | OM1092 +<br>OM1097 +<br>OM4120S | 8052PC(M)<br>OPD-C51B(N) | | 8052<br>8032 | 8k<br>0 | 256<br>256 | 15<br>15 | DIL40/PLCC44<br>DIL40/PLCC44 | UART, 3 timers<br>UART, 3 timers | | OM4111 +<br>OM4110 +<br>OM4120S | 8052PC(M)<br>OPD-C51B(N) | #### 8400 FAMILY CMOS | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PROBE<br>SDS | REMARKS | |----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------|--------------------------------------------------------------------------------| | 84C21A<br>84C41A<br>84C81A | 2k<br>4k<br>8k | 64<br>128<br>256 | 10<br>10<br>10 | DIL28/SO28<br>DIL28/SO28<br>DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C | | OM1083 | OM1025<br>(LSDS) | | 84C22A<br>84C42A<br>84C12A | 2k<br>4k<br>1k | 64<br>64<br>64 | 10<br>10<br>16 | DIL20/SO20<br>DIL20/SO20<br>DIL20/SO20<br>DIL20/SO20 | 13 I/O lines<br>8-bit timer | | OM1083 +<br>Adapter_1 | OM1025<br>(LSDS) | | 84C00B | 0 | 256 | 10 | 28 pins | 20 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C | Piggyback | OM1080 | | | 84C00T | 0 | 256 | 10 | VSO-56 | . Distance | ROMless | OM1080 | | | 84C121 | 1k | 64 | 10 | DIL20/SO20 | 13 I/O lines<br>2 8-bit timers<br>8 bytes | | OM1073 | OM1025(LEDS) | | 84C121B | 0 | 64 | 10 | `` | EEPROM | Piggyback | | OM1027 | | 84C122A<br>84C122B | 1k | 32 | 10 | A: SO20<br>B: SO24 | Controller for remote control | | OM4830 | | | 84C422A<br>84C422B | 4K | 32 | | C: SO28 | A: 12 I/O<br>B: 16 I/O | | | | | 84C822A<br>84C822B | 8K | 32 | 90.<br>1 | | C: 20 I/O | | | | | 84C822C | 47 | | | | | | | | | 84C230 | 21 | 64 | 10 | DIL40/VSO40 | 12 I/O lines<br>8-bit timer<br>16*4 LCD drive | | OM1072 | | | 84C430 | 4k | 128 | 10 | QFP64 | 24 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C | | OM1072 | | | 84C430BH | , o | 128 | 10 | | 24*4 LCD drive | Piggyback for C230<br>and C430 | | | | 84C633B | 6k<br>0 | 256<br>256 | 16 | VSO56 | 28 I/O lines<br>8-bit timer<br>16-bit up/down<br>counter<br>16-bit timer<br>with compare<br>and capture<br>16'4 LCD drive | | OM1086 | | | 84C440<br>84C441<br>84C443<br>84C444<br>84C640<br>84C641<br>84C643<br>84C644<br>84C840<br>84C841<br>84C843<br>84C843 | 4k<br>4k<br>4k<br>6k<br>6k<br>6k<br>8k<br>8k<br>8k | 128<br>128<br>128<br>128<br>128<br>128<br>128<br>128<br>129<br>192<br>192 | 10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10 | DIP42 shrunk | RC: 29 I/O lines<br>LC: 28 I/O lines<br>8-bit timer<br>1 14-bit PWM<br>5 6-bit PWM<br>3-bit ADC<br>OSD 2L-16 | 12C, RC<br>12C, LC<br>RC<br>LC<br>12C, RC<br>12C, LC<br>RC<br>LC RC<br>12C, LC<br>RC<br>RC | OM1074 | For emulation of<br>LC versions,<br>use OM1074 +<br>adapter_3 +<br>2 adapter_5 | #### 8400 FAMILY CMOS (Continued) | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PROBE<br>SDS | REMARKS | |------------------|----------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------|--------------------|----------------------| | 34C646<br>34C846 | 6k<br>8k | 192<br>192 | 10<br>10 | DIP42 shrunk | 30 I/O lines<br>DOS clock =<br>PLL | I <sup>2</sup> C, RC<br>I <sup>2</sup> C, RC | OM4829 +<br>OM4832 | OM4833 for<br>LCD584 | | | | | | | 8 bit timer<br>1-14 bit PWM<br>4-6 bit PWM<br>4-7 bit PWM | | | | | | | | | e de la companya l | 3-4 bit ADC<br>DOS: 64 disp.<br>RAM | | | | | | | | | | 62 char. fonts<br>Char. blinking<br>Shadow modes<br>8 foreground | | | | | | | | | | colors/char.<br>8 background<br>colors/word<br>DOS: clock:<br>8 20MHz | | | | | 84C85 | 8k | 256 | 10 | DIL40/VSO40 | 32 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C | | OM1070 | | | 84C85B | 0 | 256 | 10 | | | Piggyback for C85 | | | | 84C853 | 8k | 256 | 16 | DIL40/VSO40 | 33 I/O lines<br>8-bit timer<br>16-bit up/down<br>counter<br>16-bit timer with<br>compare and | | OM1081 | | | 84C853B | 0 | 256 | 16 | | capture | Piggyback for C853 | | | | 84C270<br>84C470 | 2k<br>4k | 128<br>128 | 10<br>10 | DIL40/VSO40<br>DIL40/VSO40 | 8 I/O lines<br>16*8 capture<br>keyboard matrix<br>8-bit timer | | OM1077 | | | 84C270B | 0 | 128 | 10 | | | Piggyback for C270 | | | | 84C470B | 0 | 128 | 10 | | 470 also<br>handles mech.<br>keys | Piggyback for C470 | | | | 84C271 | 2k | 128 | 10 | DIL40 | 8 I/O lines<br>16*8 mech.<br>keyboard matrix<br>8-bit timer | | OM1078 | | #### 8400 FAMILY NMOS | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | EMULATOR<br>TOOLS | REMARKS | |------------------------------|----------------------|------------------------|----------------|------------------------------------------------------|------------------------------------------------------|--------------------|-------------------|------------------------------| | 8411<br>8421<br>8441<br>8461 | 1k<br>2k<br>4k<br>6k | 64<br>64<br>128<br>128 | 6<br>6<br>6 | DIL28/SO28<br>DIL28/SO28<br>DIL28/SO28<br>DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C | | | OM1025<br>(LCDS) +<br>OM1026 | | 8422<br>8442 | 2k<br>4k | 64<br>128 | 6<br>6 | DIL20<br>DIL20 | 13 I/O lines<br>8-bit timer<br>Bit I <sup>2</sup> C | | | | | 8401B | 0 | 128 | 6 | 28-pin | | Piggyback for 84X1 | | | ### 3300 FAMILY CMOS | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PROBE<br>SDS | REMARKS | |-------|------|-----|----------------|------------|----------------------------------------------------------------------------------------------------|--------------------------------|-----------------------|--------------------------| | 3315A | 1.5k | 160 | 10 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>V <sub>DD</sub> > 1.8V | | OM1083 | OM1025(LCDS) | | 3343 | 3k | 224 | 10 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>V <sub>DD</sub> > 1.8V<br>Byte I <sup>2</sup> C | | OM1083 | OM1025(LCDS) | | 3344A | 2k | 224 | 3.58 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>DTMF generator | | OM1071 | OM1025(LCDS)<br>+ OM1028 | | 3346A | 4k | 128 | 10 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C<br>256 bytes EEPROM<br>V <sub>DD</sub> < 1.8V | | OM1076 | | | 3347 | 1.5k | 64 | 3.58 | DIL20/SO20 | 12 I/O lines<br>8-bit timer<br>DTMF generator | | OM1071 +<br>Adapter_2 | OM1025(LCDS)<br>+ OM1028 | | 3348A | 8k | 256 | 10 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>Byte I <sup>2</sup> C<br>V <sub>DD</sub> < 1.8V | | OM1083 | OM1025(LCDS) | | 3349A | 4k | 224 | 3.58 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>DTMF generator | | OM1071 | OM1025(LCDS)<br>+ OM1028 | | 3350A | 8k | 128 | 3.58 | VSO64 | 30 I/O lines<br>8-bit timer<br>DTMF generator<br>256 bytes EEPROM | | | | | 3351A | 2k | 64 | 3.58 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>DTMF generator<br>128 bytes EEPROM | | OM5000 | | | 3352A | 6k | 128 | 3.58 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>DTMF generator<br>128 byte EEPROM | | OM5000 | | | 3353A | 6k | 128 | 16 | DIL28/SO28 | 20 I/O lines<br>8-bit timer<br>DTMF generator<br>Ringer out<br>128 bytes EEPROM | March '92 | OM5000 | | | 3354A | 8k | 256 | 16 | QFP64 | 36 I/O lines<br>8-bit timer<br>DTMF generator<br>Ringer out<br>256 bytes EEPROM | June '92 | OM4829 +<br>OM5003 | OM4829: Probe base | | 8755A | 0 | 128 | 16 | DIL28/SO28 | 8k OTP<br>20 I/O lines<br>8-bit timer<br>DTMF generator<br>Melody output<br>128 bytes EEPROM | In Development | | | | 3301B | | | | | | Piggyback for 3315, 3343, 3348 | OM1083 | | | 3344B | | | | | | Piggyback for 3344, 3347, 3349 | OM1071 | | | 3346B | | | | | | Piggyback for 3346 | OM1076 | | ### 3300 FAMILY CMOS (Continued) | TYPE | ROM | RAM | SPEED<br>(MHz) | PACKAGE | FUNCTIONS | REMARKS | PROBE<br>SDS | REMARKS | |-------|-----|-----|----------------|---------|-----------|-----------------------------------|-------------------|---------| | 3350B | | | | | | Piggyback for 3350A | OM4829+<br>OM5003 | | | 3351B | | | | | | Piggyback for 3351A, 3352A, 3353A | OM5000 | | | 3354B | | | | | | Piggyback for 3354A | OM4829+<br>OM5010 | | # **CMOS 16-bit microcontroller family** ## 16-BIT CONTROLLERS (68000 ARCHITECTURE) | TYPE | (EP)ROM | RAM | SPEED<br>(MHz) | FUNCTIONS | REMARKS | PHILIPS TOOLS | THIRD-PARTY<br>TOOLS | |---------|-------------------------|-------------------------|----------------|----------------------------------------------------------------------------------------------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | 68070 | <del>-</del> | <del>-</del> | 17.5 | 2 DMA channels,<br>MMU, UART,<br>16-bit timer, I <sup>2</sup> C,<br>68000 bus interface,<br>16Mb address range | | OM4160 Microcore 1<br>OM4160/2 Microcore 2<br>OM4161 (SBE68070)<br>OM4767/2 XRAY68070SBE<br>high level symbolic debugger<br>OM4222 68070DS development<br>system<br>OM4226 XRAY68070DS<br>high level symbolic debugger | TRACE32-ICE68070<br>(Lauterbach) | | 93C101 | 34k | 512 | 15 | Derivative with low power modes | Not for new design | | | | 90CE201 | 16MB<br>external<br>ROM | 16MB<br>external<br>RAM | 24 | UART, fast I <sup>2</sup> C,<br>3 timers (16 bit),<br>Watchdog timer.<br>68000 software<br>compatible, EMC,<br>QFP64 | 25 to<br>+85°C | OM4162 Microcore 4 | TRACE32 –<br>(Lauterbach) | # 16-BIT CONTROLLERS (XA ARCHITECTURE) | TYPE | (EP)ROM | RAM | SPEED<br>(MHz) | FUNCTIONS | REMARKS | DEVELOPMENT TOOLS | |-------|---------|-----|----------------|--------------------------------|------------------|--------------------------------------| | XA-G1 | 8k | 512 | 30 | 3 timers, watchdog,<br>2 UARTs | -40 to<br>+125°C | Nohau<br>Ceibo<br>MacCraiger Systems | | XA-G2 | 16k | 512 | 30 | 3 timers, watchdog,<br>2 UARTs | -40 to<br>+125°C | Nohau<br>Ceibo<br>MacCraiger Systems | | XA-G3 | 32k | 512 | 30 | 3 timers, watchdog,<br>2 UARTs | -40 to<br>+125°C | Nohau<br>Ceibo<br>MacCraiger Systems | # **Ordering Information** #### MICROCONTROLLER PRODUCTS # **Ordering Information** March 1995 35 # **Philips Semiconductors** # Section 2 Inter-Integrated Circuit (I<sup>2</sup>C) Bus Application Notes and Development Tools for 80C51 Microcontrollers ### **CONTENTS** | The I <sup>2</sup> C-bus | and how to use it | 39 | |--------------------------|-------------------------------|----| | <sup>2</sup> C periphe | al selection guide | 58 | | 32B715 | I <sup>2</sup> C bus extender | 60 | # The I<sup>2</sup>C-bus and how to use it # (including specification) # 1.0 THE I<sup>2</sup>C-BUS BENEFITS DESIGNERS AND MANUFACTURERS In consumer electronics, telecommunications and industrial electronics, there are often many similarities between seemingly unrelated designs. For example, nearly every system includes: - Some intelligent control, usually a single-chip microcontroller - General-purpose circuits like LCD drivers, remote I/O ports, RAM, EEPROM, or data converters - Application-oriented circuits such as digital tuning and signal processing circuits for radio and video systems, or DTMF generators for telephones with tone dialling To exploit these similarities to the benefit of both systems designers and equipment manufacturers, as well as to maximize hardware efficiency and circuit simplicity, Philips developed a simple bidirectional 2-wire bus for efficient inter-IC control. This bus is called the Inter IC or I2C-bus. At present, Philips' IC range includes more than 150 CMOS and bipolar I2C-bus compatible types for performing functions in all three of the previously mentioned categories. All I<sup>2</sup>C-bus compatible devices incorporate an on-chip interface which allows them to communicate directly with each other via the I<sup>2</sup>C-bus. This design concept solves the many interfacing problems encountered when designing digital control circuits. Here are some of the features of the I2C-bus: - Only two bus lines are required; a serial data line (SDA) and a serial clock line (SCL) - Each device connected to the bus is software addressable by a unique address and simple master/slave relationships exist at all times; masters can operate as master-transmitters or as master-receivers - It's a true multi-master bus including collision detection and arbitration to prevent data corruption if two or more masters simultaneously initiate data transfer - Serial, 8-bit oriented, bidirectional data transfers can be made at up to 100 kbit/s in the standard mode or up to 400 kbit/s in the fast mode - On-chip filtering rejects spikes on the bus data line to preserve data integrity The number of ICs that can be connected to the same bus is limited only by a maximum bus capacitance of 400 pF Figure 1 shows two examples of I<sup>2</sup>C-bus applications. ### 1.1 Designer Benefits I<sup>2</sup>C-bus compatible ICs allow a system design to rapidly progress directly from a functional block diagram to a prototype. Moreover, since they 'clip' directly onto the I<sup>2</sup>C-bus without any additional external interfacing, they allow a prototype system to be modified or upgraded simply by 'clipping' or 'unclipping' ICs to or from the bus. Here are some of the features of I<sup>2</sup>C-bus compatible ICs which are particularly attractive to designers: - Functional blocks on the block diagram correspond with the actual ICs; designs proceed rapidly from block diagram to final schematic - No need to design bus interfaces because the I<sup>2</sup>C-bus interface is already integrated on-chip - Integrated addressing and data-transfer protocol allow systems to be completely software-defined - The same IC types can often be used in many different applications - Design-time reduces as designers quickly become familiar with the frequently used functional blocks represented by I<sup>2</sup>C-bus compatible ICs - ICs can be added to or removed from a system without affecting any other circuits on the bus - Fault diagnosis and debugging are simple; malfunctions can be immediately traced - Software development time can be reduced by assembling a library of reusable software modules. In addition to these advantages, the CMOS ICs in the I<sup>2</sup>C-bus compatible range offer designers special features which are particularly attractive for portable equipment and battery-backed systems. They all have: - Extremely low current consumption - High noise immunity - Wide supply voltage range - Wide operating temperature range. ### 1.2 Manufacturer benefits I<sup>2</sup>C-bus compatible ICs don't only assist designers, they also give a wide range of benefits to equipment manufacturers because - The simple 2-wire serial I<sup>2</sup>C-bus minimizes interconnections so ICs have fewer pins and there are not so many PCB tracks; result – smaller and less expensive PCBs - The completely integrated I<sup>2</sup>C-bus protocol eliminates the need for address decoders and other 'glue logic' - The multi-master capability of the I<sup>2</sup>C-bus allows rapid testing and alignment of end-user equipment via external connections to an assembly-line computer - The availability of 12C-bus compatible ICs in SO (small outline), VSO (very small outline) as well as DIL packages reduces space requirements even more. These are just some of the benefits. In addition, I2C-bus compatible ICs increase system design flexibility by allowing simple construction of equipment variants and easy upgrading to keep designs up-to-date. In this way, an entire family of equipment can be developed around a basic model. Upgrades for new equipment, or enhanced-feature models (i.e. extended memory, remote control, etc.) can then be produced simply by clipping the appropriate ICs onto the bus. If a larger ROM is needed, it's simply a matter of selecting a microcontroller with a larger ROM from our comprehensive range. As new ICs supersede older ones, it's easy to add new features to equipment or to increase its performance by simply unclipping the outdated IC from the bus and clipping on its successor. # 1.3 The ACCESS.bus Another attractive feature of the I<sup>2</sup>C-bus for designers and manufacturers is that its simple 2-wire nature and capability of software addressing make it an ideal platform for the ACCESS.bus (Fig.2). This is a lower-cost alternative for an RS-232C interface for connecting peripherals to a host computer via a simple 4-pin connector (see Section 19). Table 1. Definition of I<sup>2</sup>C-Bus Terminology | Term | Description | | | | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Transmitter | The device which sends the data to the bus | | | | | Receiver | The device which receives the data from the bus | | | | | Master | The device which initiates a transfer, generates clock signals and terminates a transfer | | | | | Slave | The device addressed by a master | | | | | Multi-master | More than one master can attempt to control the bus at the same time without corrupting the message | | | | | Arbitration | Procedure to ensure that, if more than one master simultaneously tries to control the bus, only one is allowed to do so and the message is not corrupted | | | | | Synchronization | Procedure to synchronize the clock signals of two or more devices | | | | January 1992 40 # 2.0 INTRODUCTION TO THE I<sup>2</sup>C-BUS SECIFICATION For 8-bit digital control applications, such as those requiring microcontrollers, certain design criteria can be established: - A complete system usually consists of at least one microcontroller and other peripheral devices such as memories and I/O expanders - The cost of connecting the various devices within the system must be minimized - A system that performs a control function doesn't require high-speed data transfer - Overall efficiency depends on the devices chosen and the nature of the interconnecting bus structure. In order to produce a system to satisfy these criteria, a serial bus structure is needed. Although serial buses don't have the throughput capability of parallel buses, they do require less wiring and fewer IC connecting pins. However, a bus is not merely an interconnecting wire, it embodies all the formats and procedures for communication within the system. Devices communicating with each other on a serial bus must have some form of protocol which avoids all possibilities of confusion, data loss and blockage of information. Fast devices must be able to communicate with slow devices. The system must not be dependent on the devices connected to it, otherwise modifications or improvements would be impossible. A procedure has also to be devised to decide which device will be in control of the bus and when. And, if different devices with different clock speeds are connected to the bus, the bus clock source must be defined. All these criteria are involved in the specification of the I<sup>2</sup>C-bus. ### 3.0 THE I2C-BUS CONCEPT The I<sup>2</sup>C-bus supports any IC fabrication process (NMOS, CMOS, bipolar). Two wires, serial data (SDA) and serial clock (SCL), carry information between the devices connected to the bus. Each device is recognised by a unique address - whether it's a microcontroller, LCD driver, memory or keyboard interface - and can operate as either a transmitter or receiver, depending on the function of the device. Obviously an LCD driver is only a receiver, whereas a memory can both receive and transmit data. In addition to transmitters and receivers. devices can also be considered as masters or slaves when performing data transfers (see Table 1). A master is the device which initiates a data transfer on the bus and generates the clock signals to permit that transfer. At that time, any device addressed is considered a slave. The I<sup>2</sup>C-bus is a multi-master bus. This means that more than one device capable of controlling the bus can be connected to it. As masters are usually micro-controllers, let's consider the case of a data transfer between two microcontrollers connected to the I<sup>2</sup>C-bus (Fig.3). This highlights the master-slave and receiver-transmitter relationships to be found on the I<sup>2</sup>C-bus. It should be noted that these relationships are not permanent, but only depend on the direction of data transfer at that time. The transfer of data would proceed as follows: - Suppose microcontroller A wants to send information to microcontroller B: - microcontroller A (master), addresses microcontroller B (slave) - microcontroller A (master-transmitter), sends data to microcontroller B (slave-receiver) - microcontroller A terminates the transfer. - If microcontroller A wants to receive information from microcontroller B: - microcontroller A (master) addresses microcontroller B (slave) - microcontroller A (master-receiver) receives data from microcontroller B (slave-transmitter) - microcontroller A terminates the transfer. Even in this case, the master (microcontroller A) generates the timing and terminates the transfer. The possibility of connecting more than one microcontroller to the I<sup>2</sup>C-bus means that more than one master could try to initiate a data transfer at the same time. To avoid the chaos that might ensue from such an event – an arbitration procedure has been developed. This procedure relies on the wired-AND connection of all I<sup>2</sup>C interfaces to the I<sup>2</sup>C-bus If two or more masters try to put information onto the bus, the first to produce a 'one' when the other produces a 'zero' will lose the arbitration. The clock signals during arbitration are a synchronized combination of the clocks generated by the masters using the wired-AND connection to the SCL line (for more detailed information concerning arbitration see Section 7.0). Generation of clock signals on the I<sup>2</sup>C-bus is always the responsibility of master devices; each master generates its own clock signals when transferring data on the bus. Bus clock signals from a master can only be altered when they are stretched by a slow-slave device holding-down the clock line, or by another master when arbitration occurs. # 4.0 GENERAL CHARACTERISTICS Both SDA and SCL are bidirectional lines, connected to a positive supply voltage via a pull-up resistor (see Fig.4). When the bus is free, both lines are HIGH. The output stages of devices connected to the bus must have an open-drain or open-collector in order to perform the wired-AND function. Data on the I<sup>2</sup>C-bus can be transferred at a rate up to 100 kbit/s in the standard-mode, or up to 400 kbit/s in the fast-mode. The number of interfaces connected to the bus is solely dependent on the bus capacitance limit of 400 pF. ### **5.0 BIT TRANSFER** Due to the variety of different technology devices (CMOS, NMOS, bipolar) which can be connected to the I<sup>2</sup>C-bus, the levels of the logical '0' (LOW) and '1' (HIGH) are not fixed and depend on the associated level of V<sub>DD</sub> (see Section 15.0 for Electrical Specifications). One clock pulse is generated for each data bit transferred. # 5.1 Data Validity The data on the SDA line must be stable during the HIGH period of the clock. The HIGH or LOW state of the data line can only change when the clock signal on the SCL line is LOW (see Fig.5). # **5.2 START and STOP Conditions** Within the procedure of the I<sup>2</sup>C-bus, unique situations arise which are defined as START and STOP conditions (see Fig.6). A HIGH to LOW transition on the SDA line while SCL is HIGH is one such unique case. This situation indicates a START condition. A LOW to HIGH transition on the SDA line while SCL is HIGH defines a STOP condition. START and STOP conditions are always generated by the master. The bus is considered to be busy after the START condition. The bus is considered to be free again a certain time after the STOP condition. This bus free situation is specified in Section 15.0 Detection of START and STOP conditions by devices connected to the bus is easy if they incorporate the necessary interfacing hardware. However, microcontrollers with no such interface have to sample the SDA line at least twice per clock period in order to sense the transition. 42 ## **6.0 TRANSFERRING DATA** ### 6.1 Byte Format Every byte put on the SDA line must be 8-bits long. The number of bytes that can be transmitted per transfer is unrestricted. Each byte has to be followed by an acknowledge bit. Data is transferred with the most significant bit (MSB) first (Fig.7). If a receiver can't receive another complete byte of data until it has performed some other function, for example servicing an internal interrupt, it can hold the clock line SCL LOW to force the transmitter into a wait state. Data transfer then continues when the receiver is ready for another byte of data and releases clock line SCL. In some cases, it's permitted to use a different format from the I<sup>2</sup>C-bus format (for CBUS compatible devices for example). A message which starts with such an address can be terminated by generation of a STOP condition, even during the transmission of a byte. In this case, no acknowledge is generated (see Section 9.1.3). #### 6.2 Acknowledge Data transfer with acknowledge is obligatory. The acknowledge-related clock pulse is generated by the master. The transmitter releases the SDA line (HIGH) during the acknowledge clock pulse. The receiver must pull down the SDA line during the acknowledge clock pulse so that it remains stable LOW during the HIGH period of this clock pulse (Fig.8). Of course, set-up and hold times (specified in Section 15) must also be taken into account. Usually, a receiver which has been addressed is obliged to generate an acknowledge after each byte has been received, except when the message starts with a CBUS address (see Section 9.1.3). When a slave-receiver doesn't acknowledge the slave address (for example, it's unable to receive because it's performing some real-time function), the data line must be left HIGH by the slave. The master can then generate a STOP condition to abort the transfer. If a slave-receiver does acknowledge the slave address but, some time later in the transfer cannot receive any more data bytes, the master must again abort the transfer. This is indicated by the slave generating the not acknowledge on the first byte to follow. The slave leaves the data line HIGH and the master generates the STOP condition. If a master-receiver is involved in a transfer, it must signal the end of data to the slave-transmitter by not generating an acknowledge on the last byte that was clocked out of the slave. The slave-transmitter must release the data line to allow the master to generate the STOP condition. # 7.0 ARBITRATION AND CLOCK GENERATION ### 7.1 Synchronization All masters generate their own clock on the SCL line to transfer messages on the I<sup>2</sup>C-bus. Data is only valid during the HIGH period of the clock. A defined clock is therefore needed for the bit-by-bit arbitration procedure to take place. Clock synchronization is performed using the wired-AND connection of I<sup>2</sup>C interfaces to the SCL line. This means that a HIGH to LOW transition on the SCL line will cause the devices concerned to start counting off their LOW period and, once a device clock has gone LOW, it will hold the SCL line in that state until the clock HIGH state is reached (Fig.9). However, the LOW to HIGH transition of this clock may not change the state of the SCL line if another clock is still within its LOW period. The SCL line will therefore be held LOW by the device with the longest LOW period. Devices with shorter LOW periods enter a HIGH wait-state during this time. When all devices concerned have counted off their LOW period, the clock line will be released and go HIGH. There will then be no difference between the device clocks and the state of the SCL line, and all the devices will start counting their HIGH periods. The first device to complete its HIGH period will again pull the SCL line LOW. In this way, a synchronized SCL clock is generated with its LOW period determined by the device with the longest clock LOW period, and its HIGH period determined by the one with the shortest clock HIGH period. #### 7.2 Arbitration A master may start a transfer only if the bus is free. Two or more masters may generate a START condition within the minimum hold time ( $t_{HD;STA}$ ) of the START condition which results in a defined START condition to the bus Arbitration takes place on the SDA line, while the SCL line is at the HIGH level, in such a way that the master which transmits a HIGH level, while another master is transmitting a LOW level will switch off its DATA output stage because the level on the bus doesn't correspond to its own level. Arbitration can continue for many bits. Its first stage is comparison of the address bits (addressing information is in Sections 9.0 and 13.0). If the masters are each trying to address the same device, arbitration continues with comparison of the data. Because address and data information on the I<sup>2</sup>C-bus is used for arbitration, no information is lost during this process. A master which loses the arbitration can generate clock pulses until the end of the byte in which it loses the arbitration. If a master also incorporates a slave function and it loses arbitration during the addressing stage, it's possible that the winning master is trying to address it. The losing master must therefore switch over immediately to its slave-receiver mode. Figure 10 shows the arbitration procedure for two masters. Of course, more may be involved (depending on how many masters are connected to the bus). The moment there is a difference between the internal data level of the master generating DATA 1 and the actual level on the SDA line, its data output is switched off, which means that a HIGH output level is then connected to the bus. This will not affect the data transfer initiated by the winning master. Since control of the I<sup>2</sup>C-bus is decided solely on the address and data sent by competing masters, there is no central master, nor any order of priority on the bus. Special attention must be paid if, during a serial transfer, the arbitration procedure is still in progress at the moment when a repeated START condition or a STOP condition is transmitted to the I<sup>2</sup>C-bus. If it's possible for such a situation to occur, the masters involved must send this repeated START condition or STOP condition at the same position in the format frame. In other words, arbitration isn't allowed between: - A repeated START condition and a data bit - A STOP condition and a data bit - A repeated START condition and a STOP condition. # 7.3 Use of the Clock Synchronising Mechanism as a Handshake In addition to being used during the arbitration procedure, the clock synchronization mechanism can be used to enable receivers to cope with fast data transfers, on either a byte level or a bit level. On the byte level, a device may be able to receive bytes of data at a fast rate, but needs more time to store a received byte or prepare another byte to be transmitted. Slaves can then hold the SCL line LOW after reception and acknowledgement of a byte to force the master into a wait state until the slave is ready for the next byte transfer in a type of handshake procedure. On the bit level, a device such as a microcontroller without, or with only a limited hardware I<sup>2</sup>C interface on-chip can slow down the bus clock by extending each clock LOW period. The speed of any master is thereby adapted to the internal operating rate of this device. January 1992 44 # 8.0 FORMATS WITH 7-BIT ADDRESSES Data transfers follow the format shown in Fig.11. After the START condition (S), a slave address is sent. This address is 7 bits long followed by an eighth bit which is a data direction bit (R/W) – a 'zero' indicates a transmission (WRITE), a 'one' indicates a request for data (READ). A data transfer is always terminated by a STOP condition (P) generated by the master. However, if a master still wishes to communicate on the bus, it can generate a repeated START condition (Sr) and address another slave without first generating a STOP condition. Various combinations of read/write formats are then possible within such a transfer. Possible data transfer formats are: - Master-transmitter transmits to slave-receiver. The transfer direction is not changed (Fig.12) - Master reads slave immediately after first byte (Fig.13). At the moment of the first acknowledge, the master-transmitter becomes a master-receiver and the slave-receiver becomes a slave-transmitter. This acknowledge is still generated by the slave. The STOP condition is generated by the master - Combined format (Fig.14). During a change of direction within a transfer, the START condition and the slave address are both repeated, but with the R/W bit reversed. #### NOTES: - Combined formats can be used, for example, to control a serial memory. During the first data byte, the internal memory location has to be written. After the START condition and slave address is repeated, data can be transferred. - All decisions on auto-increment or decrement of previously accessed memory locations etc. are taken by the designer of the device. - Each byte is followed by an acknowledgement bit as indicated by the A or A blocks in the sequence. - I<sup>2</sup>C-bus compatible devices must reset their bus logic on receipt of a START or repeated START condition such that they all anticipate the sending of a slave address. 45 Table 2. Definition of Bits in the First Byte | Slave address | R/ bit | Description | |---------------|-----------------------------------------|-------------------------------------------| | 0000 000 | 0 | General call address | | 0000 000 | 1 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | START byte | | 0000 001 | X | CBUS address | | 0000 010 | <b>X</b> | Address reserved for different bus format | | 0000 011 | X | Reserved for future purposes | | 0000 1XX | *** X **** | Reserved for future purposes | | 1111 1XX | X | Reserved for future purposes | | 1111 0XX | X | 10-bit slave addressing | #### NOTES: - 1. No device is allowed to acknowledge at the reception of the START byte. - The CBUS address has been reserved to enable the inter-mixing of CBUS compatible and I<sup>2</sup>C-bus compatible devices in the same system. I<sup>2</sup>C-bus compatible devices are not allowed to respond on reception of this address. - The address reserved for a different bus format is included to enable I<sup>2</sup>C and other protocols to be mixed. Only I<sup>2</sup>C-bus compatible devices that can work with such formats and protocols are allowed to respond to this address. # 9.0 7-BIT ADDRESSING (see Section 13.0 for 10-Bit Addressing) The addressing procedure for the I<sup>2</sup>C-bus is such that the first byte after the START condition usually determines which slave will be selected by the master. The exception is the 'general call' address which can address all devices. When this address is used, all devices should, in theory, respond with an acknowledge. However, devices can be made to ignore this address. The second byte of the general call address then defines the action to be taken. This procedure is explained in more detail in Section 9.1.1. # 9.1 Definition of Bits in the First The first seven bits of the first byte make up the slave address (Fig. 15). The eighth bit is the LSB (least significant bit). It determines the direction of the message. A 'zero' in the least significant position of the first byte means that the master will write information to a selected slave. A 'one' in this position means that the master will read information from the slave When an address is sent, each device in a system compares the first seven bits after the START condition with its address. If they match, the device considers itself addressed by the master as a slave-receiver or slave-transmitter, depending on the R/W bit. A slave address can be made-up of a fixed and a programmable part. Since it's likely that there will be several identical devices in a system, the programmable part of the slave address enables the maximum possible number of such devices to be connected to the I<sup>2</sup>C-bus. The number of programmable address bits of a device depends on the number of pins available. For example, if a device has 4 fixed and 3 programmable address bits, a total of 8 identical devices can be connected to the same bus. The I<sup>2</sup>C-bus committee coordinates allocation of I<sup>2</sup>C addresses. Further information can be obtained from the Philips representatives listed on the back cover. Two groups of eight addresses (0000XXX and 1111XXX) are reserved for the purposes shown in Table 2. The bit combination 11110XX of the slave address is reserved for 10-bit addressing (see Section 13). #### 9.1.1 General Call Address The general call address is for addressing every device connected to the I2C-bus. However, if a device doesn't need any of the data supplied within the general call structure, it can ignore this address by not issuing an acknowledgement. If a device does require data from a general call address, it will acknowledge this address and behave as a slave-receiver. The second and following bytes will be acknowledged by every slave-receiver capable of handling this data. A slave which cannot process one of these bytes must ignore it by not acknowledging. The meaning of the general call address is always specified in the second byte (Fig.16). There are two cases to consider: - When the least significant bit B is a 'zero' - When the least significant bit B is a 'one'. When bit B is a 'zero'; the second byte has the following definition: 46 - 00000110 (H'06'). Reset and write programmable part of slave address by hardware. On receiving this 2-byte sequence, all devices designed to respond to the general call address will reset and take in the programmable part of their address. Precautions have to be taken to ensure that a device is not pulling down the SDA or SCL line after applying the supply voltage, since these low levels would block the bus - 00000100 (H'04'). Write programmable part of slave address by hardware. All devices which define the programmable part of their address by hardware (and which respond to the general call address) will latch this programmable part at the reception of this two byte sequence. The device will not reset. - 00000000 (H'00'). This code is not allowed to be used as the second byte. Sequences of programming procedure are published in the appropriate device data sheets. The remaining codes have not been fixed and devices must ignore them. When bit B is a 'one'; the 2-byte sequence is a 'hardware general call'. This means that the sequence is transmitted by a hardware master device, such as a keyboard scanner, which cannot be programmed to transmit a desired slave address. Since a hardware master doesn't know in advance to which device the message has to be transferred, it can only generate this hardware general call and its own address – identifying itself to the system (Fig. 17). The seven bits remaining in the second byte contain the address of the hardware master. This address is recognised by an intelligent device (e.g. a microcontroller) connected to the bus which will then direct the information from the hardware master. If the hardware master can also act as a slave, the slave address is identical to the master address. In some systems, an alternative could be that the hardware master transmitter is set in the slave-receiver mode after the system reset. In this way, a system configuring master can tell the hardware master-transmitter (which is now in slave-receiver mode) to which address data must be sent (Fig. 18). After this programming procedure, the hardware master remains in the master-transmitter mode. Figure 15. The First Byte After the START Procedure Figure 16. General Call Address Format Figure 17. Data Transfer From a Hardware Master-Transmitter a. Configuring master sends dump address to hardware master b. Hardware master dumps data to selected slave Figure 18. Data Transfer by a Hardware-Transmitter Capable of Dumping Data Directly to Slave Devices ### 9.1.2 START byte Microcontrollers can be connected to the I<sup>2</sup>C-bus in two ways. A microcontroller with an on-chip hardware I<sup>2</sup>C-bus interface can be programmed to be only interrupted by requests from the bus. When the device doesn't have such an interface, it must constantly monitor the bus via software. Obviously, the more times the microcontroller monitors, or polls the bus, the less time it can spend carrying out its intended function. There is therefore a speed difference between fast hardware devices and a relatively slow microcontroller which relies on software polling. In this case, data transfer can be preceded by a start procedure which is much longer than normal (Fig.19). The start procedure consists of: - A START condition (S) - A START byte (00000001) - An acknowledge clock pulse (ACK) - A repeated START condition (Sr). After the START condition S has been transmitted by a master which requires bus access, the START byte (00000001) is transmitted. Another microcontroller can therefore sample the SDA line at a low sampling rate until one of the seven zeros in the START byte is detected. After detection of this LOW level on the SDA line, the microcontroller can switch to a higher sampling rate to find the repeated START condition Sr which is then used for synchronization. A hardware receiver will reset on receipt of the repeated START condition Sr and will therefore ignore the START byte. An acknowledge-related clock pulse is generated after the START byte. This is present only to conform with the byte handling format used on the bus. No device is allowed to acknowledge the START byte. ### 9.1.3 CBUS Compatibility CBUS receivers can be connected to the I<sup>2</sup>C-bus. However, a third bus line called DLEN must then be connected and the acknowledge bit omitted. Normally, I<sup>2</sup>C transmissions are sequences of 8-bit bytes; CBUS compatible devices have different formats. In a mixed bus structure, I<sup>2</sup>C-bus devices must not respond to the CBUS message. For this reason, a special CBUS address (0000001X) to which no I<sup>2</sup>C-bus compatible device will respond, has been reserved. After transmission of the CBUS address, the DLEN line can be made active and a CBUS-format transmission (Fig.20) sent. After the STOP condition, all devices are again ready to accept data. Master-transmitters can send CBUS formats after sending the CBUS address. The transmission is ended by a STOP condition, recognised by all devices. NOTE: If the CBUS configuration is known, and expansion with CBUS compatible devices isn't foreseen, the designer is allowed to adapt the hold time to the specific requirements of the device(s) used. # 10.0 ELECTRICAL CHARACTERISTICS FOR I<sup>2</sup>C-BUS DEVICES The electrical specifications for the I/Os of I<sup>2</sup>C-bus devices and the characteristics of the bus lines connected to them are given in Tables 3 and 4 in Section 15. I<sup>2</sup>C-bus devices with fixed input levels of 1.5 V and 3 V can each have their own appropriate supply voltage. Pull-up resistors must be connected to a 5 V $\pm$ 10% supply (Fig.21), I<sup>2</sup>C-bus devices with input levels related to V<sub>DD</sub> must have one common supply line to which the pull-up resistor is also connected (Fig.22). When devices with fixed input levels are mixed with devices with input levels related to $V_{DD}$ , the latter devices must be connected to one common supply line of 5 V $\pm$ 10% and must have pull-up resistors connected to their SDA and SCL pins as shown in Fig.23. Input levels are defined in such a way that: - The noise margin on the LOW level is 0.1 V<sub>DD</sub> - The noise margin on the HIGH level is 0.2 $\ensuremath{V_{DD}}$ - As shown in Fig.24, series resistors (R<sub>S</sub>) of e.g. 300 \( \Omega\) can be used for protection against high-voltage spikes on the SDA and SCL lines (due to flash-over of a TV picture tube, for example). # 10.1 Maximum and minimum values of resistors R<sub>D</sub> and R<sub>S</sub> For standard-mode $I^2$ C-bus devices, the values of resistors $R_p$ and $R_s$ in Fig.24 depend on the following parameters: - Supply voltage - Bus capacitance - Number of connected devices (input current + leakage current). The supply voltage limits the minimum value of resistor $R_{\rm p}$ due to the specified minimum sink current of 3 mA at $V_{OLmax}$ = 0.4 V for the output stages. $V_{DD}$ as a function of $R_p$ min is shown in Fig.25. The desired noise margin of 0.1V $_{DD}$ for the LOW level, limits the maximum value of $R_s$ . $R_s$ max as a function of $R_p$ is shown in Fig.26. The bus capacitance is the total capacitance of wire, connections and pins. This capacitance limits the maximum value of $\rm R_p$ due to the specified rise time. Fig.27 shows R<sub>p max</sub> as a function of bus capacitance. The maximum HIGH level input current of each input/output connection has a specified maximum value of 10 $\mu$ A. Due to the desired noise margin of 0.2V<sub>DD</sub> for the HIGH level, this input current limits the maximum value of R<sub>p</sub>. This limit depends on V<sub>DD</sub>. The total HIGH level input current is shown as a function of R<sub>p</sub> max in Fig.28. # 11.0 EXTENSIONS TO THE I<sup>2</sup>C-BUS SPECIFICATION The I<sup>2</sup>C-bus with a data transfer rate of up to 100 kbit/s and 7-bit addressing has now been in existence for more than ten years with an unchanged specification. The concept is accepted world-wide as a de facto standard and hundreds of different types of I<sup>2</sup>C-bus compatible ICs are available from Philips and other suppliers. The I<sup>2</sup>C-bus specification is now extended with the following two features: - A fast-mode which allows a fourfold increase of the bit rate to 0 to 400 kbit/s - 10-bit addressing which allows the use of up to 1024 additional addresses. There are two reasons for these extensions to the I<sup>2</sup>C-bus specification: - New applications will need to transfer a larger amount of serial data and will therefore demand a higher bit rate than 100 kbit/s. Improved IC manufacturing technology now allows a fourfold speed increase without increasing the manufacturing cost of the interface circuitry - Most of the 112 addresses available with the 7-bit addressing scheme have been issued more than once. To prevent problems with the allocation of slave addresses for new devices, it is desirable to have more address combinations. About a tenfold increase of the number of available addresses is obtained with the new 10-bit addressing. Figure 25. Minimum Value of $R_P$ as a Function of Supply Voltage with the Value of $R_S$ as a Parameter Figure 26. Maximum Value of $R_S$ as a Function of the Value of $R_P$ with Supply Voltage as a Parameter Figure 27. Maximum Value of Rp as a Function of Bus Capacitance for a Standard-Mode I<sup>2</sup>C-Bus Figure 28. Total HIGH Level Input Current as a Function of the Maximum Value of Rp with Supply Voltage as a Parameter All new devices with an I<sup>2</sup>C-bus interface are provided with the fast-mode. Preferably, they should be able to receive and/or transmit at 400 kbit/s. The minimum requirement is that they can synchronize with a 400 kbit/s transfer; they can then prolong the LOW period of the SCL signal to slow down the transfer. Fast-mode devices must be downward-compatible which means that they must still be able to communicate with 0 to 100 kbit/s devices in a 0 to 100 kbit/s 1<sup>2</sup>C-bus system. Obviously, devices with a 0 to 100 kbit/s I<sup>2</sup>C-bus interface cannot be incorporated in a fast-mode I<sup>2</sup>C-bus system because, since they cannot follow the higher transfer rate, unpredictable states of these devices would occur. Slave devices with a fast-mode I<sup>2</sup>C-bus interface can have a 7-bit or a 10-bit slave address. However, a 7-bit address is preferred because it is the cheapest solution in hardware and it results in the shortest message length. Devices with 7-bit and 10-bit addresses can be mixed in the same I<sup>2</sup>C-bus system regardless of whether it is a 0 to 100 kbit/s standard-mode system or a 0 to 400 kbit/s fast-mode system. Both existing and future masters can generate either 7-bit or 10-bit addresses. ### 12.0 FAST-MODE In the fast-mode of the I<sup>2</sup>C-bus, the protocol, format, logic levels and maximum capacitive load for the SDA and SCL lines quoted in the previous I<sup>2</sup>C-bus specification are unchanged. Changes to the previous I<sup>2</sup>C-bus specification are: - The maximum bit rate is increased to 400 kbit/s - Timing of the serial data (SDA) and serial clock (SCL) signals has been adapted. There is no need for compatibility with other bus systems such as CBUS because they cannot operate at the increased bit rate - The inputs of fast-mode devices must incorporate spike suppression and a Schmitt trigger at the SDA and SCL inputs - The output buffers of fast-mode devices must incorporate slope control of the falling edges of the SDA and SCL signals - If the power supply to a fast-mode device is switched off, the SDA and SCL I/O pins must be floating so that they don't obstruct the bus lines - The external pull-up devices connected to the bus lines must be adapted to accommodate the shorter maximum permissible rise time for the fast-mode I<sup>2</sup>C-bus. For bus loads up to 200 pF, the pull-up device for each bus line can be a resistor; for bus loads between 200 pF and 400 pF, the pull-up device can be a current source (3mA max.) or a switched resistor circuit as shown in Fig.37. ### 13.0 10-BIT ADDRESSING The 10-bit addressing does not change the format in the I<sup>2</sup>C-bus specification. Using 10 bits for addressing exploits the reserved combination 1111XXX for the first seven bits of the first byte following a START (S) or repeated START (Sr) condition as explained in Section 9.1. The 10-bit addressing does not affect the existing 7-bit addressing. Devices with 7-bit and 10-bit addresses can be connected to the same I<sup>2</sup>C-bus, and both 7-bit and 10-bit addressing can be used in a standard-mode system (up to 100 kbit/s) or a fast-mode system (up to 400 kbit/s). Although there are eight possible combinations of the reserved address bits 1111XXX, only the four combinations 11110XX are used for 10-bit addressing. The remaining four combinations 11111XX are reserved for future I<sup>2</sup>C-bus enhancements. # 13.1 Definition of Bits in the First Two Bytes The 10-bit slave address is formed from the first two bytes following a START condition (S) or a repeated START condition (Sr). The first seven bits of the first byte are the combination 11110XX of which the last two bits (XX) are the two most-significant bits (MSBs) of the 10-bit address; the eighth bit of the first byte is the R/W bit that determines the direction of the message. A 'zero' in the least significant position of the first byte means that the master will write information to a selected slave. A 'one' in this position means that the master will read information from the slave. If the R/W bit is 'zero', then the second byte contains the remaining 8 bits (XXXXXXXX) of the 10-bit address. If the R/W bit is 'one', then the next byte contains data transmitted from a slave to a master. # 13.2 Formats with 10-bit Addresses Various combinations of read/write formats are possible within a transfer that includes 10-bit addressing. Possible data transfer formats are: Master-transmitter transmits to slave-receiver with a 10-bit slave address. The transfer direction is not changed (Fig.29). When a 10-bit 51 address follows a START condition, each slave compares the first seven bits of the first byte of the slave address (11110XX) with its own address and tests if the eighth bit (R/W direction bit) is 0. It is possible that more than one device will find a match and generate an acknowledge (A1). All slaves that found a match will compare the eight bits of the second byte of the slave address (XXXXXXXX) with their own addresses, but only one slave will find a match and generate an acknowledge (A2). The matching slave will remain addressed by the master until it receives a STOP condition (P) or a repeated START condition (Sr) followed by a different slave address #### NOTES: - Combined formats can be used, for example, to control a serial memory. During the first data byte, the internal memory location has to be written. After the START condition and slave address is repeated, data can be transferred. - All decisions on auto-increment or decrement of previously accessed memory locations etc. are taken by the designer of the device. - Each byte is followed by an acknowledgement bit as indicated by the A or \(\overline{A}\) blocks in the sequence. - 12C-bus compatible devices must reset their bus logic on receipt of a START or repeated START condition such that they all anticipate the sending of a slave address. - Master-receiver reads slavetransmitter with a 10-bit slave address. The transfer direction is changed after the second R/W bit (Fig.30). Up to and including acknowledge bit A2, the procedure is the same as that described for a master-transmitter addressing a slave-receiver. After the repeated START condition (Sr), a matching slave remembers that it was addressed before. This slave then checks if the first seven bits of the first byte of the slave address following Sr are the same as they were after the START condition (S), and tests if the eighth (R/W) bit is 1. If there is a match, the slave considers that it has been addressed as a transmitter and generates acknowledge A3. The slave-transmitter remains addressed until it receives a STOP condition (P) or until it receives another repeated START condition (Sr) followed by a different slave address. After a repeated START condition (Sr), all the other slave devices will also compare the first seven bits of the first byte of the slave address (11110XX) with their own January 1992 - addresses and test the eighth (R/W) bit. However, none of them will be addressed because R/W = 1 (for 10-bit devices), or the 11110XX slave address (for 7-bit devices) does not match) - Combined format. A master transmits data to a slave and then reads data from the same slave (Fig.31). The same master occupies the bus all the - time. The transfer direction is changed after the second R/W bit - Combined format. A master transmits data to one slave and then transmits data to another slave (Fig.32). The same master occupies the bus all the time - Combined format. 10-bit and 7-bit addressing combined in one serial transfer (Fig.33). After each START condition (S), or each repeated START condition (Sr), a 10-bit or 7-bit slave address can be transmitted. Figure 33 shows how a master-transmits data to a slave with a 7-bit address and then transmits data to a second slave with a 10-bit address. The same master occupies the bus all the time. 52 January 1992 Table 3. Characteristics of the SDA and SCL I/O Stages for I<sup>2</sup>C-Bus Devices | Parameter | Symbol | standard-mode devices | | fast-mode devices | | Unit | |----------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------|---------------------------|---------------------------------------|---------------------------|------| | | | Min. | Max. | Min. | Max. | | | LOW level input voltage:<br>fixed input levels<br>V <sub>DD</sub> -related input levels | V <sub>IL</sub> | -0.5<br>-0.5 | 1.5<br>0.3V <sub>DD</sub> | -0.5<br>-0.5 | 1.5<br>0.3V <sub>DD</sub> | ٧ | | HIGH level input voltage:<br>fixed input levels<br>V <sub>DD</sub> -related input levels | V <sub>IH</sub> | 3.0<br>0.7V <sub>DD</sub> | *1)<br>*1) | 3.0<br>0.7V <sub>DD</sub> | *1)<br>*1) | V | | Hysteresis of Schmitt trigger inputs:<br>fixed input levels<br>V <sub>DD</sub> -related input levels | V <sub>hys</sub> | n/a<br>n/a | n/a<br>n/a | 0.2<br>0.05V <sub>DD</sub> | | V | | Pulse width of spikes which must be suppressed by the input filter | t <sub>SP</sub> | n/a | n/a | 0 | 50 | ns | | LOW level output voltage (open drain or open collector): at 3 mA sink current at 6 mA sink current | V <sub>OL1</sub><br>V <sub>OL2</sub> | 0<br>n/a | 0.4<br>n/a | 0<br>0 | 0.4<br>0.6 | V | | Output fall time from $V_{IH\ min.}$ to $V_{IL\ max.}$ with a bus capacitance from 10 pF to 400 pF: | t <sub>OF</sub> | | 250 <sup>2)</sup><br>n/a | $20 + 0.1C_b^{2)}$ $20 + 0.1C_b^{2)}$ | 250<br>250 <sup>3)</sup> | ns | | with up to 3 mA sink current at V <sub>OL1</sub> | | | 250 <sup>2)</sup> | 20 + 0.1C <sub>b</sub> <sup>2)</sup> | 250 | | | with up to 6 mA sink current at V <sub>OL2</sub> | | n/a | n/a | 20 + 0.1C <sub>b</sub> <sup>2)</sup> | 250 <sup>3)</sup> | | | Input current each I/O pin with an input voltage between 0.4 $\mathrm{V}$ and 0.9 $\mathrm{V}_{\mathrm{DD}\mathrm{max}}$ . | li li | -10 | 10 | \$10 <sup>3)</sup> | 10 <sup>3)</sup> | μА | | Capacitance for each I/O pin | Ci | · | 10 | | 10 | pF | ### NOTES: n/a = not applicable 3. I/O pins of fast-mode devices must not obstruct the SDA and SCL lines if $V_{DD}$ is switched off. <sup>1.</sup> maximum $V_{IH} = V_{DD max.} + 0.5 V$ C<sub>b</sub> = capacitance of one bus line in pF. Note that the maximum t<sub>F</sub> for the SDA and SCL bus lines quoted in Table 4 (300 ns) is longer than the specified maximum t<sub>OF</sub> for the output stages (250 ns). This allows series protection resistors (R<sub>s</sub>)to be connected between the SDA/SCL pins and the SDA/SCL bus lines as shown in Fig.37 without exceeding the maximum specified t<sub>F</sub>. # 14.0 GENERAL CALL ADDRESS AND START BYTE The 10-bit addressing procedure for the $I^2C$ -bus is such that the first two bytes after the START condition (S) usually determine which slave will be selected by the master. The exception is the 'general call' address 00000000 (H'00'). Slave devices with 10-bit addressing will react to a 'general call' in the same way as slave devices with 7-bit addressing (see Section 9.1.1). Hardware masters can transmit their 10-bit address after a 'general call'. In this case, the 'general call' address byte is followed by two successive bytes containing the 10-bit address of the master-transmitter. The format is as shown in Fig.17 where the first DATA byte contains the eight least-significant bits of the master address. The START byte 00000001 (H'01') can precede the 10-bit addressing in the same way as for 7-bit addressing (see Section 9.1.2). # 15.0 ELECTRICAL SPECIFICATIONS The I/O levels, I/O current, spike suppression, output slope control and pin capacitance for I<sup>2</sup>C-bus devices are given in Table 3. The I<sup>2</sup>C-bus timing is given in Table 4. Figure 34 shows the timing definitions for the I<sup>2</sup>C-bus. The noise margin for HIGH and LOW levels on the bus lines for fast-mode devices are the same as those specified in Section 10.0 for standard-mode I<sup>2</sup>C-bus devices. The minimum HIGH and LOW periods of the SCL clock specified in Table 4 determine the maximum bit transfer rates of 100 kbit/s for standard-mode devices and 400 kbit/s for fast mode devices. Standard-mode and fast-mode I<sup>2</sup>C-bus devices must be able to follow transfers at their own maximum bit rates, either by being able to transmit or receive at that speed or by applying the clock synchronization procedure described in Section 7 which will force the master into a wait state and stretch the LOW period of the SCL signal. Of course, in the latter case the bit transfer rate is reduced. # 16.0 APPLICATION INFORMATION # 16.1 Slope-Controlled Output Stages of Fast-Mode I<sup>2</sup>C-Bus Devices The electrical specifications for the I/Os of I<sup>2</sup>C-bus devices and the characteristics of the bus lines connected to them are given in Tables 3 and 4 in Section 15. Figures 35 and 36 show examples of output stages with slope control in CMOS and bipolar technology. The slope of the falling edge is defined by a Miller capacitor (C1) and a resistor (R1). The typical values for C1 and R1 are indicated on the diagrams. The wide tolerance for output fall time $t_{OF}$ given in Table 3 means that the design is not critical. The fall time is only slightly influenced by the external bus load (C<sub>b</sub>) and external pull-up resistor (R<sub>p</sub>). However, the rise time (t<sub>R</sub>) specified in Table 4 is mainly determined by the bus load capacitance and the value of the pull-up resistor. # 16.2 Switched Pull-Up Circuit for Fast-Mode I<sup>2</sup>C-Bus Devices The supply voltage (V<sub>DD</sub>) and the maximum output LOW level determine the minimum value of pull-up resistor R<sub>p</sub> (see Section 10.1). For example, with a supply voltage of V<sub>DD</sub> = 5V $\pm$ 10% and V<sub>OL max.</sub> = 0.4 V at 3 mA, R<sub>p min.</sub> = (5.5 – 0.4)/0.003 = 1.7 k $\Omega$ . As shown in Fig.38, this value of R<sub>p</sub> limits the maximum bus capacitance to about 200 pF to meet the maximum t<sub>R</sub> requirement of 300 ns. If the bus has a higher capacitance than this, a switched pull-up circuit as shown in Fig.37 can be used. The switched pull-up circuit in Fig.37 is for a supply voltage of $V_{DD}$ = 5 $\,V\,\pm\,10\,$ % and a maximum capacitive load of 400 pF. Since it is controlled by the bus levels, it needs no additional switching control signals. During the rising/falling edges, the bilateral switch in the HCT4066 switches pull-up resistor $R_p2$ on/off at bus levels between 0.8 $\,V$ and 2.0 $\,V$ . Combined resistors $R_p1$ and $R_p2$ can pull-up the bus line within the maximum specified rise time ( $t_R$ ) of 300 ns. The maximum sink current for the driving $l^2C$ -bus device will not exceed 6 mA at $V_{OL2}$ = 0.6 $\,V$ , or 3 mA at $V_{OL1}$ = 0.4 $\,V$ . Series resistors $\rm R_{\rm S}$ are optional. They protect the I/O stages of the I/2C-bus devices from high-voltage spikes on the bus lines, and minimize crosstalk and undershoot of the bus line signals. The maximum value of $\rm R_{\rm S}$ is determined by the maximum permitted voltage drop across this resistor when the bus line is switched to the LOW level in order to switch off $\rm R_{\rm n}2$ . # 16.3 Wiring Pattern of the Bus In general, the wiring must be so chosen that crosstalk and interference to/from the bus lines is minimized. The bus lines are most susceptible to crosstalk andinterference at the HIGH level because of the relatively high impedance of the pull-up devices. If the length of the bus lines on a PCB or ribbon cable exceeds 10 cm and includes the V<sub>DD</sub> and V<sub>SS</sub> lines, the wiring pattern must be: | SDA | | | | | |------------------------------|---------------|-------|--------|------------| | V <sub>DD</sub> | | | | | | V <sub>SS</sub> | | | | | | SCL | | | | | | f only the V <sub>SS</sub> I | | uded, | the wi | ring | | Jallem must be | ):<br>. , , , | | | | | SDA | i: | | | 14<br>147) | | | | | | | These wiring patterns also result in identical capacitive loads for the SDA and SCL lines. The V<sub>SS</sub> and V<sub>DD</sub> lines can be omitted if a PCB with a V<sub>SS</sub> and/or V<sub>DD</sub> layer is used. If the bus lines are twisted-pairs, each bus line must be twisted with a $V_{SS}$ return. Alternatively, the SCL line can be twisted with a $V_{SS}$ return, and the SDA line twisted with a $V_{DD}$ return. In the latter case, capacitors must be used to decouple the $V_{DD}$ line to the $V_{SS}$ line at both ends of the twisted pairs. If the bus lines are shielded (shield connected to $V_{SS}$ ), interference will be minimized. However, the shielded cable must have low capacitive coupling between the SDA and SCL lines to minimize crosstalk. # 16.4 Maximum and Minimum Values of Resistors R<sub>p</sub> and R<sub>s</sub> for Fast-Mode I<sup>2</sup>C-Bus Devices The maximum and minimum values for resistors $R_p$ and $R_s$ connected to a fast-mode $l^2C$ -bus can be determined from Fig.25, 26 and 28 in Section 10.1. Because a fast-mode $l^2C$ -bus has faster rise times ( $t_R$ ) the maximum value of $R_p$ as a function of bus capacitance is less than that shown in Fig.27 The replacement graph for Fig.27 showing the maximum value of $R_p$ as a function of bus capacitance ( $C_b$ ) for a fast mode $l^2C$ -bus is given in Fig.38. Table 4. Characteristics of the SDA and SCL Bus Lines for I<sup>2</sup>C-Bus Devices | Parameter | Symbol | Standard-mode<br>I <sup>2</sup> C-bus | | Fast-mode<br>I <sup>2</sup> C-bus | | Unit | |--------------------------------------------------------------------------------------------------------------|----------------------|---------------------------------------|------|--------------------------------------|------------------------|----------| | | | Min. | Max. | Min. | Max. | 1 | | SCL clock frequency | f <sub>SCL</sub> | 0 | 100 | 0 | 400 | kHz | | Bus free time between a STOP and START condition | t <sub>BUF</sub> | 4.7 | | 1.3 | - | μs | | Hold time (repeated) START condition. After this period, the first clock pulse is generated | t <sub>HD</sub> ;STA | 4.0 | - | 0.6 | | μs | | LOW period of the SCL clock | t <sub>LOW</sub> | 4.7 | • | 1.3 | - · | μs | | HIGH period of the SCL clock | t <sub>HIGH</sub> | 4.0 | - | 0.6 | - | μs | | Set-up time for a repeated START condition | tsu;sta | 4.7 | - | 0.6 | - | μs | | Data hold time:<br>for CBUS compatible masters (see NOTE, Section 9.1.3)<br>for I <sup>2</sup> C-bus devices | t <sub>HD;DAT</sub> | 5.0<br>0 <sup>1)</sup> | | -<br>01) | -<br>0.9 <sup>2)</sup> | μs<br>μs | | Data set-up time | t <sub>SU;DAT</sub> | 250 | - | 100 <sup>3)</sup> | - | ns | | Rise time of both SDA and SCL signals | t <sub>R</sub> | - | 1000 | 20 + 0.1C <sub>b</sub> <sup>4)</sup> | 300 | ns | | Fall time of both SDA and SCL signals | t <sub>F</sub> | | 300 | 20 + 0.1C <sub>b</sub> <sup>4)</sup> | 300 | ns | | Set-up time for STOP condition | t <sub>SU;STO</sub> | 4.0 | - | 0.6 | - | μs | | Capacitive load for each bus line | C <sub>b</sub> | - | 400 | - | 400 | pF | ### NOTES: All values referred to $V_{\text{IH min.}}$ and $V_{\text{IL max.}}$ levels (see Table 3). - A device must internally provide a hold time of at least 300 ns for the SDA signal (referred to the V<sub>IH min.</sub> of the SCL signal) in order to bridge the undefined region of the falling edge of SCL. - 2. The maximum t<sub>HD;DAT</sub> has only to be met if the device does not stretch the LOW period (t<sub>LOW</sub>) of the SCL signal. - 3. A fast-mode I<sup>2</sup>C-bus device can be used in a standard-mode I<sup>2</sup>C-bus system, but the requirement t<sub>SU;DAT</sub> ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line t<sub>R max</sub>. + t<sub>SU;DAT</sub> = 1000 + 250 = 1250 ns (according to the standard-mode I<sup>2</sup>C-bus specification) before the SCL line is released. - 4. C<sub>b</sub> = total capacitance of one bus line in pF. 55 January 1992 # 17.0 DEVELOPMENT TOOLS # 17.1 Development tools for 8048 and 8051-based systems | Product | Description | |---------|---------------------------------------------------------------------------------------------------------------------------------------------| | OM1016 | 12C-bus demonstration board with microcontroller, LCD, LED, Par. I/O, SRAM, EEPROM, Clock, DTMF generator, AD/DA conversion, infrared link. | | OM1018 | manual for OM1016 | | OM1020 | LCD and driver demonstration board | | OM4151 | l <sup>2</sup> C-bus evaluation board (similar to OM1016 above but without infrared link). | # 17.2 Development tools for 68000-based systems | Product | Description | |----------|-------------------------------------------------------------------------------------------------------------------------------------------| | OM4160 | Microcore-1 demonstration/evaluation board:<br>SCC68070, 128K EPROM, 512K DRAM, I <sup>2</sup> C, RS-232C, VSC SCC66470, resident monitor | | OM4160/3 | Microcore-3 demonstration/evaluation board:<br>93C110, 128K EPROM, 64K SRAM, I <sup>2</sup> C, RS-232C, 40 I/O, resident monitor | # 17.3 Development tools for all systems | Product | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OM1022 | I <sup>2</sup> C-bus analyzer. Hardware and software (runs on IBM or compatible PC) to experiment with and analyze the behaviour of the I <sup>2</sup> C-bus (includes documentation) | 56 January 1992 ### 18.0 SUPPORT LITERATURE # Data handbooks IC01 1992: Semiconductors for radio and audio systems IC02 1992: Semiconductors for television and video systems IC03 1993: Semiconductors for telecom systems IC14 1992: 8048-based 8-bit microcontrollers IC20 1994: 8051-based 8-bit microcontrollers Brochures/leaflets Microcontrollers and microprocessors for embedded control applications I²C-bus compatible ICs and support overview I²C-bus control programs for consumer applications # 19.0 APPLICATION OF THE I<sup>2</sup>C-BUS IN THE ACCESS.bus SYSTEM The ACCESS.bus (bus for connecting ACCESSory devices to a host system) is an I<sup>2</sup>C-bus based open-standard serial interconnect system jointly developed and defined by Philips Semiconductors and Digital Equipment, Corporation, It is a lower-cost alternative to an RS-232C interface for connecting up to 14 inputs/outputs from peripheral equipment to a desk-top computer or workstation over a distance of up to eight metres. The peripheral equipment can be relatively low speed items such as keyboards, hand-held image scanners, cursor positioners, bar-code readers, digitizing tablets, card readers or modems. All that's required to implement an ACCESS.bus is an 8051-family microcontroller with an I<sup>2</sup>C-bus interface, and a 4-wire cable carrying a serial data (SDA) line, a serial clock (SCL) line, a ground wire and a 12 V supply line (500 mA max.) for powering the peripherals. Important features of the ACCESS.bus are that the bit rate is only about 20% less than the maximum bit rate of the I<sup>2</sup>C-bus, and the peripherals don't need separate device drivers. Also, the protocol allows the peripherals to be changed by 'hot-plugging' without re-booting. As shown in Fig.39, the ACCESS.bus protocol comprises three levels: the I<sup>2</sup>C-bus protocol, the base protocol, and the application protocol. The base protocol is common to all ACCESS bus devices and defines the format of the ACCESS.bus message. Unlike the I<sup>2</sup>C-bus protocol, it restricts masters to sending and slaves to receiving data. One item of appended information is a checksum for reliability control. The base protocol also specifies seven types of control and status messages which are used in the system configuration which assigns unique addresses to the peripherals without the need for setting jumpers or switches on the devices. The application protocol defines the message semantics that are specific to the three categories of peripheral device (keyboards, cursor locators, and text devices which generate character streams e.g. card readers) which are at present envisaged. Philips Semiconductors offers computer peripheral equipment manufacturers technical support, a wide range of I<sup>2</sup>C-bus devices and development kits for the ACCESS.bus. Hardware, software and marketing support is also offered by DEC. # I<sup>2</sup>C peripheral selection guide | GENERAL F | PURPOSE ICs | 80C51-Base | | SAA9051 | Digital multistandard<br>(PAL/NTSC) colour | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------------------------|--------------------|---------------------------------------------------------| | LCD Drivers | Signatura de la companya de la companya de la companya de la companya de la companya de la companya de la comp | 83CL267/167 | 12k ROM, 256 RAM OSD | 04400=0 | decoder | | PCF8566 | 96-segment LCD driver<br>1:1 – 1:4 Mux rates | 83CL268/168 | 12k ROM, 256 RAM OSD | SAA9056 | Digital SECAM colour decoder | | PCF8567 | LCD direct mode driver | 8XCL410 | 4k ROM/128 RAM,<br>low power | SAA9057B | Clock signal generation circuit for digital video | | PCF8568 | LCD row driver for dot matrix displays | 8XC528 | 32k ROM/512 RAM, T2, WD | | systems; for use with SAA90xx | | PCF8569 | LCD Column driver for dot matrix displays | 8XC542 | 4k ROM/128 RAM,<br>ACCESS.bus | SAA9065 | Video enhancement and D/A processor | | PCF8576 | 160-segment LCD driver | 8XC552 | 256-byte RAM/8k ROM/<br>ADC/UART/PWM | TDA4680 | Video processor | | PCF8577C | 1:1 – 1:4 Mux rates<br>64-segment LCD driver | 8XCL580 | 6k ROM, 256 RAM,<br>low power | TDA8440 | Video/audio switch | | * | 1:1 - 1:2 Mux Rates | 8XC652 | 256-byte RAM/8k ROM, | Video/Radio | /Audio | | PCF8578/79 | Row/column LCD | | UART | SAA4700 | VPS dataline processor | | | dot-matrix driver/display<br>1:8 – 1:32 Mux rates | 8XC654 | 256-byte RAM/16kROM,<br>UART | SA5751 | Audio Processor/Filter<br>Controller | | LED Drivers | <b>.</b> | 8XC751 | 64-byte RAM/2k ROM | SAA5243 | Computer controlled text circuit | | SAA1064 | 4-digit LED driver | 8XC752 | 64-byte RAM/2k ROM,<br>ADC/PWM | SAA5246 | Computer controlled text circuit | | I/O Expande | 8-bit remote I/O port | | ction-Set Based CMOS | SAA5248 | Integrated teletext decoder and VPS slicer | | . OI 03/4/A | (I <sup>2</sup> C-bus to parallel | Microcontro | | SAA5252 | Closed caption | | PCF8584 | converter) 8-bit parallel to I <sup>2</sup> C | PCF84C00 | 256-byte RAM/bond-out<br>version for prototype | SAA7158 | Line frequency processor and DAC circuit | | | converter | D0504004 | development | SAA7194 | Digital video decoder/scaler | | SAA1300 | 5-bit high-current driver | PCF84C21<br>PCF84C41 | 64-byte RAM/2k ROM<br>128-byte RAM/2k ROM | SAA9042 | Digital video teletext<br>(DVTB) processor | | Data Converters | | PCF84C81 | 256-byte RAM/8k ROM | SAB3035/36/37 | Digital tuning circuits for | | PCF8591 | 4-channel, 8-bit Mux ADC + one DAC | PCF84C85 | 256-byte RAM/8k ROM/<br>Extended I/O | TDA1551 | computer-controlled TV<br>2 X 22W BTL audio power | | TDA8442<br>TDA8444 | Quad 6-bit DAC<br>Octal 6-bit DAC | PCF84C430 | 128-byte RAM/4k ROM/<br>96-segment LCD driver | TDA1551Q | amp<br>2 X 22W BTL audio power | | | Octal o-bit DAO | | | TDA4670 | amp with diagnostic Picture signal improvement | | Memory | | MULTIMEDI | A ICs | <b>TD 4 407</b> 4 | circuit | | PCA8581 | 128-byte EEPROM | | | TDA4671 | Picture signal improvement<br>circuit | | PCF8570/C | 256-byte static RAM | Desktop Vic | leos | TDA4681 | Video processor with | | PCF8571<br>PCF8582 | 128-byte static RAM<br>256-byte EEPROM | SAA7151B | 8-bit digital multistandard<br>TV decoder | | automatic cut-off and white level control | | PCF8583 | 256-byte | SAA7152 | Digital comb filter | TDA4685 | Video processor | | PCF8594 | RAM/clock/calendar | SAA7157 | Clock signal generation | TDA4686 | Video processor (100 Hz) | | PCF8594<br>PCF8598 | 512-byte EEPROM | | circuit for digital video | TDA4687 | Video processor | | | 1K-byte EEPROM | | systems; for use with SAA71xx | TDA8415 | TV/VCR stereo/dual sound processor | | Clocks/Cale<br>PCF8573 | | SAA7165 | Video enhancement and<br>D/A processor including | TDA8416 | TV/VCR stereo/dual sound processor | | PCF8573<br>PCF8583 | Clock/calendar | | digital CTI | TDA8417 | TV/VCR stereo/dual sound | | FCF0303 | Clock/calendar/<br>256-byte RAM | SAA7186 | Digital video scaler | | processor | | 68000-Based | | SAA7191 | Digital multistandard TV decoder, square pixel | TDA8421 | Audio processor with a loudspeaker channel and a | | Microcontro | | SAA7191B | SAA7191 variant | | headphone channel | | INTERPORTURE OF THE PROPERTY O | 68000 CPU/MMU/UART/ | SAA7192A | Digital colour space converter with independent | TDA8425 | Audio processor with a<br>loudspeaker channel only | | 68070 | | | | | | | 68070<br>93CXXX | DMA/timer<br>UST/I <sup>2</sup> C/34k ROM/ | SAA7199B | LHT<br>digital multistandard | TDA8426<br>TDA8433 | Hi-fi stereo audio processor<br>TV deflection processor | March 1995 58 # I<sup>2</sup>C peripheral selection guide | Video/Radio/ | Audio (Continued) | Telecom | | |---------------|--------------------------------------------------------------------|------------|--------------------------------------------------| | TDA9140 | Alignment-free multistandard decoder | NE5750/51 | Audio processor pair | | TEA6320 | 4 input Tone/volume controller with fader control | NE5752 | 3 V 5750 variant (samples<br>Q4 92) | | TEA6330 | Tone/volume controller | NE5753 | 3 V 5751 variant (samples | | TSA6060 | A/M Frequency Synthesizer for RDS. | | Q4 92) | | TDA8433 | Deflection processor | PCD3311/12 | Tone generator (DTMF/modem/musical) | | TDA8442 | Interface for color decoders | | | | TDA8443/A | YUV/RGB matrix switch | PCD3341 | Advanced 10 to 110-number repertory | | TDA8461 | PAL/NTSC color decoder<br>and RGB processor | | dialer with LCD control | | TDA8466 | PAL/NTSC color decoder<br>and RGB processor | PCD3343 | Microcontroller with<br>224-byte RAM/3k ROM | | TDA9150 | Deflection processor | PCD3348 | Microcontroller with | | TDA9860 | Sound controller w/ 4 inputs | | 256-byte RAM/8k ROM | | TEA6100 | FM/IF and digital tuning IC for computer-controlled radio | PCD4440 | Analog voice<br>scrambler/descrambler | | TEA6300 | Sound fader control and preamplifier/source selector for car radio | UMA1000T | Data processor for mobile telephones | | TSA5511/12/14 | PLL frequency synthesizer for TV | UMA1014T | 1GHz frequency synthesizer for mobile telephones | | TSA6057 | PLL frequency synthesizer for radio | UMF1009 | Frequency synthesizer | | | | | | Also available with extended temperature ranges. FOR FURTHER INFORMATION ON THESE DEVICES, REFER TO I<sup>2</sup>C-PERIPHERALS FOR MICROCONTROLLERS DATA HANDBOOK, AVAILABLE FROM YOUR LOCAL PHILIPS SEMICONDUCTORS SALES OFFICE (SEE INSIDE BACK COVER OF THIS BOOK). March 1995 59 # I<sup>2</sup>C bus extender 82B715 ### DESCRIPTION The 82B715 is a bipolar integrated circuit intended for application in I<sup>2</sup>C bus systems. While retaining all the operating modes and features of the $I^2C$ system it permits extension of the practical separation distance between components on the $I^2C$ bus by buffering both the data (SDA) and the clock (SCL) lines. The I<sup>2</sup>C bus capacitance limit of 400pF restricts practical communication distances to a few meters. Using one 82B715 at each end of longer cables reduces the cable loading capacitance on the I<sup>2</sup>C bus by a factor of 10 times and may allow the use of low cost general purpose wiring to extend bus lengths. # **FEATURES** - Dual, bi-directional, unity voltage gain buffer - I<sup>2</sup>C bus compatible - Logic signal levels may include both supply and ground - X10 impedance transformation - Wide supply voltage range # **PIN CONFIGURATIONS** ### **PINNING** | PIN | SYMBOL | FUNCTION | |-----|-----------------|----------------------------------| | 1 | N.C. | | | 2 | L <sub>X</sub> | Buffered Bus, LDA or LCL | | 3 | S <sub>X</sub> | I <sup>2</sup> C Bus, SDA or SCL | | 4 | GND | Negative Supply | | 5 | N.C. | | | 6 | Sy | I <sup>2</sup> C Bus, SCL or SDA | | 7 | Ly | Buffered Bus, LCL or LDA | | 8 | V <sub>CC</sub> | Positive Supply | # **QUICK REFERENCE DATA** | | | LIMITS | | | | |-----------------------------------|--------------------------|--------|------|-----------------|------| | SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT | | V <sub>CC</sub> | Supply voltage | 4.5 | | 12 | ٧ | | Icc | Quiescent current | | 16 | | mA | | lline | Output sink capability | 30 | | | mA | | V <sub>in</sub> | Input voltage range | 0 | | V <sub>CC</sub> | V | | V <sub>out</sub> | Output voltage range | 0 | | V <sub>CC</sub> | V | | Z <sub>in</sub> /Z <sub>out</sub> | Impedance transformation | 8 | 10 | 13 | | | T <sub>amb</sub> | Temperature range | -40 | | +85 | °C | ### ORDERING INFORMATION | DESCRIPTION | ORDER CODE | DRAWING NUMBER | |--------------------------------------------------------------------|------------|----------------| | 8-Pin Plastic Dual In-Line (N/P) Package | P82B715P N | SOT97 | | 8-Pin Plastic SOL (Small Outline Large) Dual In-Line (D/T) Package | P82B715T D | SOT96A | | 82B715 is available in | chip form | | 60 1992 Dec 09 I<sup>2</sup>C bus extender 82B715 ### **FUNCTIONAL DESCRIPTION** The 82B715 bipolar integrated circuit contains two identical buffer circuits which enable I<sup>2</sup>C and similar bus systems to be extended over long distances without degradation of system performance or requiring the use of special cables. The buffer has an effective current gain of ten from I<sup>2</sup>C bus to Buffered bus. Whatever current is flowing out of the I<sup>2</sup>C bus side, ten times that current will be flowing into the Buffered bus side (see Figure 2). As a consequence of this amplification the system is able to drive capacitive loads up to ten times the standard limit on the Buffered bus side. This current based buffering approach preserves the bi-directional, open-collector/open-drain characteristic of the I<sup>2</sup>C SDA/SCL lines. To minimize interference and ensure stability, current rise and fall rates are internally controlled. ### **APPLICATION NOTES** By using two (or more) 82B715 ICs, a sub-system can be built which retains the interface characteristics of an I<sup>2</sup>C device so that it may be included in, or optionally added to, any I<sup>2</sup>C or related system. The sub-system features a low impedance or "Buffered" bus, capable of driving large wiring capacities (see Figure 3). # I<sup>2</sup>C Systems As with the standard I<sup>2</sup>C system, pull-up resistors are required to aprovide the logic HIGH levels on the Buffered bus. (Standard open-collector configuration of the I<sup>2</sup>C bus). The size and number of these pull-up resistors depends on the system. If the buffer is to be permanently connected into the system, the circuit should be configured with only one pull-up resistor on the Buffered bus and none on the I<sup>2</sup>C bus. Alternatively a buffer may be connected to an existing I<sup>2</sup>C system. In this case the Buffered bus pull-up will act in parallel with the I<sup>2</sup>C bus pull-up. Figure 1. Block Diagram: 82B715 Figure 2. Equivalent Circuit: One Half 82B715 82B715 # I<sup>2</sup>C bus extender Figure 3. Minimum Sub-System with 82B715 # **RATINGS** Limiting values in accordance with the Absolute Maximum System (IEC 134). Voltages with respect to pin GND (DIL-8 pin 4). | | | LIMITS | | | |------------------------|------------------------------------------------|--------|-----------------|------| | SYMBOL | PARAMETER | MIN. | MAX. | UNIT | | V <sub>CC</sub> to GND | Supply voltage range V <sub>CC</sub> | -0.3 | +12 | V | | V <sub>bus</sub> | Voltage range I <sup>2</sup> C Bus, SCL or SDA | 0 | V <sub>CC</sub> | ٧ | | V <sub>buff</sub> | Voltage range Buffered Bus | 0 | V <sub>CC</sub> | ٧ | | 1 | DC current (any pin) | | 60 | mA | | P <sub>tot</sub> | Power dissipation | | 300 | mW | | T <sub>stg</sub> | Storage temperature range | -55 | +125 | °C | | T <sub>amb</sub> | Operating ambient temperature range | -40 | +85 | °C | # **CHARACTERISTICS** At $T_{amb}$ = +25°C and $V_{CC}$ = 5 Volts, unless otherwise specified. | SYMBOL | | | LIMITS | | | |-----------------------------------|-------------------------------------------------------------------------------------------------------------------|------|-------------|---------------|------| | | PARAMETER | MIN. | TYP. | MAX. | UNIT | | Power Supply | | | <del></del> | | | | V <sub>CC</sub> | Supply voltage (operating) | 4.5 | | 12 | V | | lcc | Supply current | | 16 | | mA | | lcc | Supply current at V <sub>CC</sub> = 12V | | 22 | | mA | | lcc | Supply current, both I <sup>2</sup> C inputs LOW, both buffered outputs sinking 30mA. | _ | 28 | _ | mA | | <b>Drive Currents</b> | | | <del></del> | - <del></del> | | | I <sub>Sx</sub> , I <sub>Sy</sub> | Output sink on $I^2C$ bus $V_{Sx}$ , $V_{Sy}$ LOW = 0.4V $V_{Lx}$ , $V_{Ly}$ LOW on Buffered bus = 0.3V | 3 | T - | _ | mA | | l <sub>Lx</sub> , l <sub>Ly</sub> | Output sink on Buffered bus $V_{Lx}$ , $V_{Ly}$ LOW = 0.4V $V_{Sx}$ , $V_{Sy}$ LOW on I <sup>2</sup> C bus = 0.3V | 30 | | | mA | | Input Currents | | | | <del></del> | · | | I <sub>Sx</sub> , I <sub>Sy</sub> | Input current from I <sup>2</sup> C bus when I <sub>LX</sub> , I <sub>Ly</sub> sink on Buffered bus = 30mA | | _ | 3 | mA | | I <sub>Lx</sub> , I <sub>Ly</sub> | Input current from Buffered bus when $I_{Sx}$ , $I_{Sy}$ sink on $I^2C$ bus = 3mA | • - | _ | 3 | mA | | l <sub>Lx</sub> , l <sub>Ly</sub> | Leakage current on Buffered bus $V_{Lx}$ , $V_{Ly} = V_{CC}$ , and $V_{Sx}$ , $V_{Sy} = V_{CC}$ | | _ | 200 | μА | | Impedance Trar | nsformation | 14.1 | | | A | | Z <sub>in</sub> /Z <sub>out</sub> | Input/Output impedance | 8 | 10 | 13 | | 1992 Dec 09 62 Philips Semiconductors Preliminary specification I<sup>2</sup>C bus extender 82B715 ### **Pull-Up Resistance Calculation** In calculating the pull-up resistance values, the gain of the buffer introduces scaling factors which must be applied to the system components. Viewing the system from the Buffered bus, all I<sup>2</sup>C bus capacitances have effectively 10 times their I<sup>2</sup>C bus value. In practical systems the pull-up resistance is determined by the rise time limit for I<sup>2</sup>C systems. As an approximation this limit will be satisfied if the time constant (product of the net resistance and net capacitance) of the total system is set to 1 microsecond. The total time constant may either be set by considering each bus node individually (i.e., the I<sup>2</sup>C nodes, and the Buffered bus node) and choosing pull-up resistors to give time constants of 1 microsecond for each node; or by combining the capacitances into an equivalent capacitive loading on the Buffered bus, and calculating the Buffered bus pull-up resistor required by this equivalent capacitance. For each separate bus the pull-up resistor may be calculated as follows: $$R = \frac{1\mu sec}{C_{device} + C_{wiring}}$$ Where: C<sub>device</sub> = sum of device capacitances connected to each bus, and C<sub>wiring</sub> = total wiring and stray capacitance on each bus. If these capacitances are not known then a good approximation is to assume that each device presents 10pF of load capacitance and 10pF of wiring capacitance. The capacitance figures for one or more individual I2C bus nodes should be multiplied by a factor of 10 times, and then added to the Buffered bus capacitance. Calculation of a new Buffered bus pull-up resistor will alllow this single pull-up resistor to act for both the included I2C bus nodes and the Buffered bus. Thus it is possible to combine some or all of these separate pull-up resistors into a single resistor on the Buffered bus (the value of which is calculated from the sum of the scaled capacitances on the Buffered bus). If the buffer is to be permanently connected into the system then all the separate pull-up resistors should be combined. But if it is to be connected by adding it onto an existing system, then only those on the additional I2C bus system can be combined onto the Buffered bus if the original system is required to be able to still operate on a stand-alone A further restriction is that the maximum pull-up current, with the bus LOW, should not exceed the I<sup>2</sup>C bus specification maximum of 3mA, or 30mA on the Buffered bus. The following formula applies: $$30\text{mA} > \frac{\text{V}_{\text{CC}} - 0.4}{\text{R}_{\text{P}}}$$ Where: R<sub>P</sub> = scaled parallel combination of all pull-up resistors. If this condition is met, the fall time specifications will also be met. Figure 4 shows typical loading calculations for the expanded I<sup>2</sup>C bus. ### Sx, Sy, I2C Bus, SDA or SCL Because the two buffer circuits in the 82B715 are identical either input pin can be used as the I<sup>2</sup>C Bus SDA data line, or the SCL clock line # Lx, Ly, Buffered Bus, LDA or LCL On the buffered low impedance line side, the corresponding output becomes LDA and LCL. # V<sub>CC</sub>, GND — Positive and Negative Supply Pins In normal use the power supply voltages at each end of the low impedance line should be comparable. If these differ by a significant amount, noise margin is sacrificed. 1992 Dec 09 63 # I<sup>2</sup>C bus extender 82B715 ### EFFECTIVE CAPACITANCE NEAR I<sup>2</sup>C DEVICES | 2 × I <sup>2</sup> C Devices | 20pF | |------------------------------|------| | Strays | 20pF | | 82B715 Buffer | 10pF | | TOTAL CAP. | 50pF | I2C pull-up $$R1 = \frac{1\mu \sec}{50pF} = 20K\Omega$$ # EFFECTIVE CAPACITANCE BUFFERED LINE | Wiring Cap. | 3000pF | |-------------|--------| | TOTAL CAP. | 3000pF | | | | Buffered Bus pull-up $$R2 = \frac{1\mu \sec}{3000pF} = 333\Omega$$ ### EFFECTIVE CAPACITANCE REMOTE I<sup>2</sup>C DEVICES | 1 × I <sup>2</sup> C Devices | 10pF | |------------------------------|------| | Strays | 10pF | | 82B715 Buffer | 10pF | | TOTAL CAP. | 30pF | I2C pull-up $$R3 = \frac{1\mu \sec}{30pF} = 33K\Omega$$ # AS AN ADDITION TO AN EXISTING SYSTEM \*: $$R1 = 20K\Omega$$ $$R2' = \frac{R2 \times 0.1R3}{R2 + 0.1R3} = 300\Omega$$ R3 not required since buffer always connected ### FOR A PERMANENT SYSTEM \*: R1 not required since buffer always connected $$R2' = \frac{0.1R1 \times R2 \times 0.1R3}{0.1R1 + R2 + 0.1R3} = 260\Omega$$ R3 not required since buffer always connected #### \* NOTE R1, R2 and R3 are calculated from the capacitive loading and a 1µsec time constant on each bus node. For an addition to an existing system, R2' (the new value for R2) is shown as being calculated from the parallel combination of R2 and the scaled value of R3; while for a permanent system R2, and scaled values of R1 and R3 have been used. Note that this example has used scaled resistor values and combined the node and cable capacitances. ### **CHECK FOR MAXIMUM PULL-UP CURRENT:** $$\frac{(5-0.4)V}{260\Omega} = 17.6mA < 30mA$$ SU00294 Figure 4. Typical Loading Calculation: I<sup>2</sup>C Bus with 82B715 1992 Dec 09 64 # **Philips Semiconductors** # **Section 3** I<sup>2</sup>C Serial Bus Application Notes & Articles # Application Notes and Development Tools for 80C51 Microcontrollers ### CONTENTS | AN422 | Using the 8XC751 microcontroller as an I <sup>2</sup> C bus master | 67 | |-------------|---------------------------------------------------------------------------------------|-----| | AN425 | Interfacing the PCD8584 I $^2$ C-bus controller to 80C51 family microcontrollers $$ . | 85 | | AN430 | Using the 8XC751/752 in multimaster I <sup>2</sup> C applications | 104 | | AN433 | I <sup>2</sup> C slave routines for the 83C751 | 140 | | AN434 | Connecting a PC keyboard to the I <sup>2</sup> C-bus | 146 | | AN438 | I <sup>2</sup> C routines for 8XC528 | 164 | | AN444 | Using the P82B715 I <sup>2</sup> C extender on long cables | 186 | | ETV/AN89004 | PLM51 I <sup>2</sup> C software interface IIC51 (version 0.5) | 206 | | EIE/AN91007 | I <sup>2</sup> C driver routines for 8XC751/2 microcontrollers | 215 | | | Programming the I <sup>2</sup> C interface | 269 | Philips Semiconductors Application note # Using the 8XC751 microcontroller as an I<sup>2</sup>C bus master **AN422** ### **DESCRIPTION** The 83C751/87C751 Microcontroller offers the advantages of the 80C51 architecture in a small package and at a low cost. It combines the benefits of a high-performance microcontroller with on-board hardware supporting the Inter-Integrated Circuit (I<sup>2</sup>C) bus interface. The I<sup>2</sup>C bus, developed and patented by Philips, allows integrated circuits to communicate directly with each other via a simple bidirectional 2-wire bus. The comprehensive family of CMOS and bipolar ICs incorporating the on-chip I<sup>2</sup>C interface offers many advantages to designers of digital control for industrial, consumer and telecommunications equipment. A typical system configuration is shown in Figure 1. Figure 1. Typical I<sup>2</sup>C Bus Configuration Interfacing the devices in an I<sup>2</sup>C based system is very simple because they connect directly to the two bus lines: a serial data line (SDA) and a serial clock line (SCL). System design can rapidly progress from block diagram to final schematic, as there is no need to design bus interfaces, and functional blocks on a block diagram correspond to actual ICs. A prototype system or a final product version can easily be modified or upgraded by 'clipping' or 'unclipping' ICs to or from the bus. The simplicity of designing with the I<sup>2</sup>C bus does not reduce its effectiveness; it is a reliable, multimaster bus with integrated addressing and data-transfer protocols (see Figure 2). In addition, the I<sup>2</sup>C-bus compatible ICs provide cost reduction benefits to equipment manufacturers, some of which are smaller IC packages and a minimization of PCB traces and glue logic. The availability of microcontrollers like the 83C751, with on-board I<sup>2</sup>C interface, is a very powerful tool for system designers. The integrated protocols allow systems to be completely software defined. Software development time of different products can be reduced by assembling a library of reusable software modules. In addition, the multimaster capability allows rapid testing and alignment of end-products via external connections to an assembly-line computer. The mask programmable 83C751 and its EPROM version, the 87C751, can operate as a master or a slave device on the I<sup>2</sup>C small area network. In addition to the efficient interface to the dedicated function ICs in the I<sup>2</sup>C family, the on-board interface facilities I/O and RAM expansion, access to EEPROM and processor-to-processor communications. The multimaster capability of the I<sup>2</sup>C is very important but many designs do not require it. For many systems, it is sufficient that all communications between devices are initiated by a single, master processor. In this application note, use of the 8XC751 as an I<sup>2</sup>C bus master is described. Some of the technical features of the bus and the 83C751's special hardware associated with the I<sup>2</sup>C are discussed. Also included is a software example demonstrating I<sup>2</sup>C single master communications. Note that the sample routines are quite general, and therefore may be transferred easily to many applications. The discussion of the I<sup>2</sup>C bus characteristics in this application note is by no means complete. Additional information for the I<sup>2</sup>C bus and the S83C751 Microcontroller can be found in the Microcontroller Users' Guide. # THE I2C BUS The two lines of the I<sup>2</sup>C-bus are a serial data line (SDA) and a serial clock line (SCL). Both lines are connected to a positive supply via a pull-up resistor, and remain HIGH when the bus is not busy. Each device is recognized by a unique address—whether it is a microcomputer, LCD driver, memory or keyboard interface—and can operate as either a transmitter or receiver, depending on the function of the device. A device generating a message or data is a transmitter, and a device receiving the message or data is a receiver. Obviously, a passive function like an LCD driver could only be a receiver, while a microcontroller or a memory can both transmit and receive data. ### **Masters and Slaves** When a data transfer takes place on the bus, a device can either be a master or a slave. The device which initiates the transfer, and generates the clock signals for this transfer, is the master. At that time any device addressed is considered a slave. It is important to note that a master could either be a transmitter or a receiver; a master microcontroller may send data to a RAM acting as a transmitter, and then interrogate the RAM for its contents acting as a receiver—in both cases performing as the master initiating the transfer. In the same manner, a slave could be both a receiver and a transmitter. The I<sup>2</sup>C is a multimaster bus. It is possible to have, in one system, more than one device capable of initiating transfers and controlling the bus (Figure 2). A microcontroller may act as a master for one transfer, and then be the slave for another transfer, initiated by another processor on the network. The master/slave relationships on the bus are not permanent, and may change on each transfer. Figure 2. I<sup>2</sup>C Bus Connection # Using the 8XC751 microcontroller as an I<sup>2</sup>C bus master AN422 As more than one master may be connected to the bus, it is possible that two devices will try to initiate a transfer at the same time. Obviously, in order to eliminate bus collisions and communications chaos, an arbitration procedure is necessary. The I<sup>2</sup>C design has an inherent arbitration and clock synchronization procedure relying on the wired-AND connection of the devices on the bus. In a typical multimaster system, a microcontroller program should allow it to gracefully switch between master and slave modes and preserve data integrity upon loss of arbitration. In this note, a simple case is presented describing the S83C751 operating as a single master on the bus. ### **Data Transfers** One data bit is transferred during each clock pulse (see Figure 3). The data on the SDA line must remain stable during the HIGH period of the clock pulse in order to be valid. Changes in the data line at this time will be interpreted as control signals. A HIGH-to-LOW transition of the data line (SDA) while the clock signal (SCL) is HIGH indicates a Start condition, and a LOW-to-HIGH transition of the SDA while SCL is HIGH defines a Stop condition (see Figure 4). The bus is considered to be busy after the Start condition and free again at a certain time interval after the Stop condition. The Start and Stop conditions are always generated by the master. The number of data bytes transferred between the Start and Stop condition from transmitter to receiver is not limited. Each byte, which must be eight bits long, is transferred serially with the most significant bit first, and is followed by an acknowledge bit. (see Figure 5). The clock pulse related to the acknowledge bit is generated by the master. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, while the transmitting device releases the SDA line (HIGH) during this pulse (see Figure 6). Figure 3. Bit Transfer on the I<sup>2</sup>C Bus Figure 4. Start and Stop Conditions Figure 5. Data Transfer on the I2C Bus Figure 6. Acknowledge on the I<sup>2</sup>C Bus Philips Semiconductors Application note # Using the 8XC751 microcontroller as an I<sup>2</sup>C bus master AN422 A slave receiver must generate an acknowledge after the reception of each byte, and a master must generate one after the reception of each byte clocked out of the slave transmitter. If a receiving device cannot receive the data byte immediately, it can force the transmitter into a wait state by holding the clock line (SCL) LOW. When designing a system, it is necessary to take into account cases when acknowledge is not received. This happens, for example, when the addressed device is busy in a real time operation. In such a case the master, after an appropriate "time-out", should abort the transfer by generating a Stop condition, allowing other transfers to take place. These "other transfers" could be initiated by other masters in a multimaster system, or by this same master. There are two exceptions to the "acknowledge after every byte" rule. The first occurs when a master is a receiver: it must signal an end of data to the transmitter by NOT signalling an acknowledge on the last byte that has been clocked out of the slave. The acknowledge related clock, generated by the master should still take place, but the SDA line will not be pulled down. In order to indicate that this is an active and intentional lack of acknowledgement, we shall term this special condition as a "negative acknowledge". The second exception is that a slave will send a negative acknowledge when it can no longer accept additional data bytes. This occurs after an attempted transfer that cannot be accepted. The bus design includes special provisions for interfacing to microprocessors which implement all of the I<sup>2</sup>C communications in software only—it is called "Slow Mode". When all of the devices on the network have built-in I<sup>2</sup>C hardware support, the Slow Mode is irrelevant ### Addressing and Transfer Formats Each device on the bus has its own unique address. Before any data is transmitted on the bus, the master transmits on the bus the address of the slave to be accessed for this transaction. A well-behaved slave with a matching address, if it exists on the network, should of course acknowledge the master's addressing. The addressing is done by the first byte transmitted by the master after the Start condition. An address on the network is seven bits long, appearing as the most significant bits of the address byte. The last bit is a direction (R/W) bit. A zero indicates that the master is transmitting (WRITE) and a one indicates that the master requests data (READ). A complete data transfer, comprised of an address byte indicating a WRITE and two data bytes is shown in Figure 7. When an address is sent, each device in the system compares the first seven bits after the Start with its own address. If there is a match, the device will consider itself addressed by the master, and will send an acknowledge. The device could also determine if in this transaction it is assigned the role of a slave receiver or slave transmitter, depending on the R/W bit. Each node of the I<sup>2</sup>C network has a unique seven bit address. The address of a microcontroller is of course fully programmable, while peripheral devices usually have fixed and programmable address portions. In addition to the "standard" addressing discussed here, the I<sup>2</sup>C bus protocol allows for "general call" addressing and interfacing to CBUS devices. When the master is communicating with one device only, data transfers follow the format of Figure 7, where the R/W bit could indicate either direction. After completing the transfer and issuing a Stop condition, if a master would like to address some other device on the network, it could of course start another transaction, issuing a new Start Another way for a master to communicate with several different devices would be by using a "repeated start". After the last byte of the transaction was transferred, including its acknowledge (or negative acknowledge), the master issues another Start, followed by address byte and data—without effecting a Stop. The master may communicate with a number of different devices, combining READS and WRITES. After the last transfer takes place, the master issues a Stop and releases the bus. Possible data formats are demonstrated in Figure 8. Note that the repeated start allows for both change of a slave and a change of direction, without releasing the bus. We shall see later on that the change of direction feature can come in handy even when dealing with a single device. In a single master system, the repeated start mechanism may be more efficient than terminating each transfer with a Stop and starting again. In a multimaster environment, the determination of which format is more efficient could be more complicated, as when a master is using repeated starts it occupies the bus for a long time and thus preventing other devices from initiating transfers. Figure 7. A Complete Data Transfer on the I<sup>2</sup>C-Bus # Using the 8XC751 microcontroller as an I<sup>2</sup>C bus master AN422 Figure 8. I2C Data Formats Figure 9. I<sup>2</sup>C Sub-Address Usage AN422 #### Use of Sub-Addresses For some ICs on the I<sup>2</sup>C bus, the device address alone is not sufficient for effective communications, and a mechanism for addressing the internals of the device is necessary. A typical example when we want to access a specific word inside the device is addressing memories, or a sequence of memory locations starting at a specific internal address. A typical I<sup>2</sup>C memory device like the PCF8570 RAM contains a built-in word address register that is incremented automatically after each data byte which is a read or written data byte. When a master communicates with the PCF8570 it must send a sub-address in the byte following the slave address byte. This sub-address is the internal address of the word the master wants to access for a single byte transfer, or the beginning of a sequence of locations for a multi-byte transfer. A sub-address is an 8-bit byte, unlike the device address, it does not contain a direction (R/W) bit, and like any byte transferred on the bus it must be followed by an acknowledge. A memory write cycle is shown in Figure 9(a). The Start is followed by a slave byte with the direction bit set to WRITE, a sub-address byte, a number of data bytes and a Stop signal. The sub-address is loaded into the word address memory, and the data bytes which follow will be written one after the other starting with the sub-address location, as the register is incremented automatically. The memory read cycle (see Figure 9(b)) commences in a similar manner, with the master sending a slave address with the direction bit set to WRITE with a following sub-address. Then, in order to reverse the direction of the transfer, the master issues a repeated Start followed again by the memory device address, but this time with the direction bit set to READ. The data bytes starting at the internal sub-address will be clocked out of the device, each followed by a master-generated acknowledge. The last byte of the read cycle will be followed by a negative acknowledge, signalling the end of transfer. The cycle is terminated by a Stop signal. #### 8XC751 I2C HARDWARE The on-chip I<sup>2</sup>C bus hardware support of the 8XC751 allows operation on the bus at full speed, and simplifies the software needed for effective communications on the network. The hardware activates and monitors the SDA and SCL lines, performs the necessary arbitration and framing errors checks, and takes care of clock stretching and synchronization. The hardware support includes a bus time-out timer, called Timer I. The hardware is synchronized to the software either through polled loops or interrupts. Two of the port 0 pins are multi-functional. When the $I^2C$ is active, the pin associated with P0.0 functions as SCL, and the pin associated with P0.1 functions as SDA. These pins have an open drain output. Two of the five 8XC751 interrupt sources may be used for $|^2C$ support. The $|^2C$ interrupt is enabled by the El2 flag of the interrupt enable register, and its service routine should start at address 023h. An $|^2C$ interrupt is usually requested (if enabled) when a rising edge of SCL indicates a new data bit on the bus, or a special condition occurs: Start, Stop or arbitration loss. The interrupt is induced by the ATN flag—see below for the conditions for setting this flag. The Timer I overflow interrupt is enabled by the ETI flag, and the service routine starts at 018h. The I<sup>2</sup>C port is controlled through three special function registers: I<sup>2</sup>C Control (I2CON), I<sup>2</sup>C Configuration (I2CFG), and I<sup>2</sup>C Data (I2DAT). The register addresses are shown in Table 1. Although the following discussion of the hardware and register details is not complete, it should give a better understanding of the programming examples. #### Timer In I<sup>2</sup>C applications, Timer I is dedicated to the port timing generation and bus monitoring. In non-I<sup>2</sup>C applications, it is available for use as a fixed time base. In its port timing generation function, Timer I is used to generate SCL, the I<sup>2</sup>C clock. Timer I is clocked once per machine cycle (osc/12), so that the toggle rate of SCL will be some multiple of that rate. Because the 83C751 can be run over a wide range of oscillator frequencies, it is necessary to adjust SCL for the part's oscillator frequency. This allows the I<sup>2</sup>C bus to be used at its highest transfer rates independent of the oscillator frequency. SCL is adjusted by writing to two bits (CT0 and CT1) in the I2CFG special function register (see Table 2). The inverse of the values in CT0 and CT1 are loaded into the least significant two bit locations of Timer I every time the fourth bit of the timer is toggled. (A value is actually loaded into the least significant three bits, the third bit being 0 unless both CT0 and CT1 are programmed high and in that case the third bit is 1). SCL is then toggled every time the fourth bit of Timer I is toggled. For example: if CT1 = 0 and CT0 = 1 then the least significant three bits of Timer I would be preloaded with 2 (010 binary). Timer I would then count 3, 4, 5, 6, 7, 8 (6 counts or machine cycles). On 8, the fourth bit of Timer I will toggle, SCL will toggle and the 3 least significant bits will again be preloaded with the value 2 (010). Table 1. I<sup>2</sup>C Special Function Register Addresses | R | EGISTER | | BIT ADDRESS | | | | | | | | | |--------------------------------|---------|---------|----------------|----------|---------|----|----------|--------------------|----|-----|--| | Name | Symbol | Address | MSB | | | | | | | LSB | | | I <sup>2</sup> C Control | I2CON | 98 | 9F | 9E | 9D | 9C | 9B | 9A | 99 | 98 | | | I <sup>2</sup> C Data | I2DAT | 99 | <sup>1</sup> - | <u> </u> | - ^- ^- | | <u>-</u> | · · · · · <u>-</u> | - | - | | | I <sup>2</sup> C Configuration | I2CFG | D8 | DF | DE | DD | DC | DB | DA | D9 | D8 | | Table 2. CT0, CT1 Timer I Settings | CT1 Values | CT0 Values | Timer I Counts | Oscillator Freq (MHz) | | | |------------|------------|----------------|-----------------------|--|--| | <br>1 | 0 | 7 | 16 | | | | 0 | 1 | 6 | 15, 14, 13 | | | | 0 | 0 | 5 | 12, 11 | | | | 1 | 1 | 4 | 10 or less | | | Timer I counts = f<sub>OSC</sub> (MHz) x 0.39 (rounded up to next integer). Philips Semiconductors Application note ### Using the 8XC751 microcontroller as an I<sup>2</sup>C bus master AN422 For the bus monitoring function, Timer I is used as a "watchdog timer" for bus hang-ups. It creates an interrupt when the SCL line stays in one state for an extended period of time while the bus is active 'between a Start condition and a following Stop condition). SCL "stuck low" indicates a faulty master or slave. SCL "stuck high" may mean a faulty device, or that noise induced unto the I<sup>2</sup>C caused all masters to withdraw from the I<sup>2</sup>C arbitration. The time-out interval of Timer I is fixed (cannot be set): it carries out and interrupts (if enabled) when about 1024 machine cycles have elapsed since a change on SCL within a frame. In other words, whenever I²C is active and Timer I is enabled, the falling edge of SCL will reset Timer I. If SCL is not toggled low for 1024 machine cycles, Timer I will overflow and cause an interrupt. (Note: we wrote "about 1024 machine cycles" although for the sake of accuracy—this number is affected by the setting of the CT0 and CT1 bits mentioned above and may vary by up to three machine cycles) The exact number of cycles for a time-out is not critical; what is important is that it indicates SCL is stuck. In addition to the interrupt, upon Timer I overflow the I<sup>2</sup>C port hardware is reset. This is useful for multiple master systems in situations where a bus fault might cause the bus to hang-up due to a lack of software response. When this happens, SCL will be released, and I<sup>2</sup>C operation between other devices can continue. #### **I2CON Register** The I<sup>2</sup>C control register (I2CON) can be written to (see Figure 10). When writing to the I2CON register, one should use bit masks as demonstrated in the example program. Trying to clear or set the bits in the register using the bit addressing capabilities of the 8XC751 may lead to undesirable results. The reason is that a command like CLR reads the register, sets the bit and writes it back, and the write-back may affect other bits. #### **I2CFG Register** The configuration register (I2CFG) is a read/write register (see Figure 11). #### **I2DAT Register** The I<sup>2</sup>C data register (I2DAT) is a read/write register, where the MSB represents the data received or data to be sent. The other seven bits are read as 0 (see Figure 12). #### **Transmit Active State** The transmit active state—Xmit Active—is an internal state in the $I^2C$ interface that is affected by the $I^2C$ registers as explained above. The $I^2C$ interface will only drive the SDA line low when Xmit Active is set. Xmit Active is set by writing the $I^2DAT$ register, or by writing $I^2CON$ with XSTR = 1 or XSTP = 1. The ARL bit will be set to 1 only when Xmit Active is set—in such a case Xmit Active will be automatically reset upon arbitration loss. Xmit Active is cleared by writing 1 to CXA at $I^2CON$ register or by reading the $I^2DAT$ register. Figure 10. I2CON Register Philips Semiconductors Application note ### Using the 8XC751 microcontroller as an I<sup>2</sup>C bus master AN422 Figure 11. I2CFG Register Figure 12. I2DAT Register #### PROGRAMMING EXAMPLE The listing demonstrates communications routines for the 8XC751 as an I<sup>2</sup>C bus master in a single-master system. The single-master system is less complicated than a multimaster environment. The programmer does not have to worry about switching between master and slave roles, or the consequences of an arbitration loss. The I<sup>2</sup>C interrupt is not used, and therefore disabled. There is no need for frame Start interrupts, as this processor is the only bus master and all data transfers are initiated by it when the appropriate routines are called by the application. No one else generates frame Starts which could be an interrupt source in a multimaster system. Within the frames we monitor bus activity with a wait-loop which polls the ATN flag. As we expect the bus to operate in its full-speed mode, we can assume that only a small amount of time will be wasted in those loops, and the use of interrupts would be less efficient. The 8XC751 has single-bit I<sup>2</sup>C hardware interface, where the registers may directly affect the levels on the bus and the software interacting with the register takes part in the protocol implementation. The hardware and the low-level routines dealing with the registers are tightly coupled. Therefore, one should take extra care if trying to modify these lower level routines. The beginning of the program, at address 0, contains the reset vector, where the microcontroller begins executing code after a hardware reset. In this case, the code simply jumps to the main part of the program, which begins at the label 'Reset' near the end of the listing. The main program is a simple demonstration of the I<sup>2</sup>C routines which comprise the balance of the listing. It first enables the Timer I interrupt, and sets up some sample data to be transmitted. Beginning at the label MainLoop, the program then proceeds to transmit one byte of data to a slave device at address 48 hexadecimal, using the routine titled 'SendData'. In our demonstration hardware, this address corresponds to an 8-bit I/O port that drives eight monitor LEDs. The program then reads back one byte of data from the same port using the routine 'RcvData'. The SendData and RcvData routines can send or receive multiple bytes of data, the number of which is determined by the variable 'ByteCnt'. Upon return from both SendData and RcvData, the program checks the system flag named 'Retry' to see if the transfer was completed correctly. If not, it loops back and attempts the same transfer again. Next, the program sends four bytes of data to a 256-byte EEPROM device, an 8-pin part called the PCF8582. The routine 'SendSub' is used for this purpose. The EEPROM was located at address A0 hexadecimal on our board. This device uses the sub-addressing feature to select a starting location to address in the EEPROM array. When data is written to the EEPROM, the address is automatically incremented so that the data bytes are stored in consecutive locations. Finally the program reads back four bytes of data from the EEPROM using the routine 'RcvSub'. Calls to SendSub and RcvSub should also be followed by a test of the Retry flag to insure that all went according to plan. AN422 This entire process is repeated indefinitely by jumping back to MainLoop. Back at the beginning of the program, the next location after the reset vector is the Timer I interrupt service routine. The microcontroller will go to address 1B hexadecimal if Timer I overflows. This routine stops the timer, clears the timer interrupt, clears the pending interrupt so that other interrupts will be enabled, restores the stack pointer, and jumps to the 'Recover' routine to try to correct whatever stopped the I<sup>2</sup>C bus and allowed Timer I to overflow. Next in the listing come the main I<sup>2</sup>C service routines. These are the routines SendData, RcvData, SendSub, and RcvSub that were called from the main program. Both of the send routines use the data area labeled 'XmtDat' as the transmit data buffer. In this sample program, four bytes were reserved for this area, but it could be larger or smaller depending on the application. The two receiver routines use another four byte buffer labeled 'RcvDat' to store received data. All of these routines use the variables 'SlvAdr' and 'ByteCnt' to determine the slave address and the number of bytes to be sent or received, respectively. The SendSub and RcvSub routines use the variable 'SubAdr' as the sub-address to send to the slave device. Following the main I<sup>2</sup>C service routines in the listing are the subroutines that are called by the main routines to deal intimately with the I<sup>2</sup>C hardware. The 'SendAddr' subroutine requests mastership of the I<sup>2</sup>C bus and calls the routine 'XmitAddr' to complete sending the slave address. The bulk of the XmitAddr routine is shared with the 'XmitByte' subroutine which sends data bytes on the I<sup>2</sup>C bus. XmitByte is also used to send I<sup>2</sup>C sub-addresses. Both subroutines check for an acknowledge from the slave device after every byte is sent on the I<sup>2</sup>C bus. The next subroutine 'RDAck' calls the 'RcvByte' routine to read in a byte of data. It then sends an acknowledge to the slave device. RDAck is used to receive all data except for the last byte of a receive data frame, where the acknowledge is omitted by the bus master. The RcvByte subroutine is called directly for the last byte of a frame. The 'SendStop' subroutine causes a stop condition on the $l^2C$ , thus ending a frame. The 'RepStart' subroutine sends a repeated start condition on the $l^2C$ bus, to allow the master to start a new frame without first having to send an intervening stop. The lower level subroutines deal directly with the hardware. The tight coupling between hardware and software is best demonstrated by the following explanations, relating to two cases in which the code is not self evident. #### **Sending the Address** When sending the address byte in the Send Addr subroutine, the first bit is written to I2DAT prior to the loop where the other seven bits are sent (SendAd2). The reason is that we need to clear the Start condition in order to release the SCL line, and this is done explicitly by the subsequent command. When SCL is released, the correct bit (MSB of address) must already be in I2DAT. #### Capturing the Received Data Typically, a program receiving data waits in a loop for ATN, and when detected, checks DRDY. If DRDY = 1 then there was a rising SCL, and the new data can be read from RDAT in I2CON or I2DAT. Reading or writing I2DAT clears DRDY, thus releasing SCL. When reading the last bit in a byte, it should be read from I2CON, and not I2DAT (see the end of the RcvByte routine). This way the Data Ready (DRDY) flag is not cleared, and the low period on SCL is stretched. The reason for doing so is that upon reception of the last bit of a received byte the master must react with an acknowledge. In order to ensure that we "wait" with the acknowledge clock (release of SCL) until the acknowledge level is issued on SDA, the last bit is read out of I2CON and not I2DAT. SCL is stretched low until the acknowledge level is written into I2DAT by the software. #### **Bus Faults and Other Exceptions** Bus exceptions are detected either by Timer I time-out, or "illegal" logic states tested for and detected by the software. Upon Timer I time-out, a bus recovery is attempted by the Recover routine. The final section of the listing is this 'Recover' routine. Its job is to try to restore control of the I²C bus to the main program. First, the subroutine 'FixBus' is called. It checks to see if only the SDA line is 'stuck', and if so, tries to correct it by sending some extra clocks on the SCL line, and forcing a stop condition on the bus. If this does not work, another subroutine 'BusReset' is called. This generally happens when a severe bus error occurs, such as a shorted clock line. The philosophy used in this code is that the only chance of recovering from a severe error is to cause a reset of the I¹C hardware by deliberately forcing Timer I to time out. This method allows recovery from a temporary short or other serious condition on the I²C bus. | I2CAPP | 83C751 | Single Mast | er I2C | Routines | 09/07/89 | |--------|--------|-------------------|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 | | | | | | | 2 | ;****** | ***** | ***** | ****** | | | 3 | ; | | | | | | 4 | ; Sample | I2C Sin | gle Master | r Routines for the 83C751 | | | 5 | | | | | | | 6 | ; * * * * * * * * | ***** | ***** | ******* | | | 7 | | | | | | | 8 | \$TITLE(83C | 751 Sing | le Master | I2C Routines) | | | 9 | \$DATE(09/0 | 7/89) | | | | | 10 | \$MOD751 | | | | | | 11 | \$DEBUG | | | | | | 12 | | | | | | | 13 | | | | | | | 14 | ; Value de | finition | ıs. | | | | 15 | | | | | | 0002 | 16 | CTVAL | EQU | 02h | ;CT1, CT0 bit values for I2C. | | 000- | 17 | | | | | | | 18 | | | | | | | 19 | ; Masks fo | r I2CFG | bits. | | | | 20 | , | | | | | 0010 | 21 | BTIR | EQU | 10h | ;Mask for TIRUN bit. | | 0040 | 22 | BMRQ | EQU | 40h | ;Mask for MASTRQ bit. | | 0040 | 23 | Dinte | 200 | 1011 | | | | 24 | | | | | | | 25 | ; Masks fo | r T2CON | hits. | | | | 26 | , nasks ro | 1 110011 | 2100. | | | 0080 | 27 | BCXA | EQU | 80h | ; Mask for CXA bit. | | 0040 | 28 | BIDLE | EQU | 40h | ;Mask for IDLE bit. | | 0020 | 29 | BCDR | EQU | 20h | :Mask for CDR bit. | | 0010 | | BCARL | EQU | 10h | Mask for CARL bit. | | 0008 | 31 | BCSTR | EQU | 08h | Mask for CSTR bit. | | 0004 | 32 | BCSTP | EQU | 04h | Mask for CSTP bit. | | 0001 | 33 | BXSTR | EQU | 02h | :Mask for XSTR bit. | | 0001 | 34 | BXSTP | EQU | 01h | Mask for XSTP bit. | | 0001 | 35 | DADII | LIQU | 0 111 | , indicate the second s | | | 36 | | | | | | | 37 | ; RAM loca | tions 11 | sed by T2C | routines. | | | 38 | , 1411 1000 | CIOID G | bed by III | | | 0021 | 39 | BitCnt | DATA | 21h | :I2C bit counter. | | 0021 | 40 | ByteCnt | DATA | 22h | , | | 0022 | 41 | SlvAdr | DATA | 23h | :Address of active slave. | | 0023 | 42 | SubAdr | DATA | 24h | | | 5024 | 43 | | | | | | 0025 | 44 | RcvDat | DATA | 25h | ; I2C receive data buffer (4 bytes). | | 0023 | 45 | 1101240 | | | ; addresses 25h through 28h. | | | 46 | | | | , | | 0029 | 47 | XmtDat | DATA | 29h | ; I2C transmit data buffer (4 bytes). | | 0023 | 48 | Innebae | 2 | 27 | ; addresses 29h through 2Ch. | | | 49 | | | | , | | 002D | 50 | StackSave | DATA | 2Dh | ;Saves stack addr for bus recovery. | | 0025 | 51 | beackbave | D | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | 0020 | 52 | Flags | DATA | 20h | ;I2C software status flags. | | 0000 | 53 | NoAck | BIT | | ;Indicates missing acknowledge. | | 0001 | 54 | Fault | BIT | | ;Indicates a bus fault of some kind. | | 0001 | 55 | Retry | BIT | | ;Indicates that last I2C transmission | | 0002 | 56 | Weer A | | 11495.2 | ; failed and should be repeated. | | | 57 | | | | , rarra and broard to repeated. | | 0080 | 58 | SCL | BIT | P0.0 | ;Port bit for I2C serial clock line. | | 0080 | 59 | SDA | BIT | P0.1 | ;Port bit for I2C serial data line. | | 0001 | 60 | SDA | | 10.1 | , , , , , , , , , , , , , , , , , , , , | | | 00 | | | | | ``` 62 Begin Code ******************* 63 64 65 ; Reset and interrupt vectors. 66 0000 21E1 67 AJMP Reset ;Reset vector at address 0. 68 69 70 ; A timer I timeout usually indicates a 'hung' bus. 71 001B 72 ORG 1Bh ;Timer I (I2C timeout) ; interrupt. 001B D2DD 73 TimerI: SETB CLRTI ;Clear timer I interrupt. 001D C2DC 74 CLR TIRUN 001F 1126 75 ACALL ClrInt ;Clear interrupt pending. 0021 852D81 76 MOV SP, StackSave ;Restore stack for return ; to main. 0024 218A 77 AJMP Recover ;Attempt bus recovery. 0026 32 ClrInt: RETI 78 79 80 81 ****************** 82 Main Transmit and Receive Routines 83 ********************** 84 85 ; Send data byte(s) to slave. 86 ; Enter with slave address in SlvAdr, data in XmtDat buffer, ; # of data bytes to send in ByteCnt. 87 88 0027 C200 89 SendData: CLR NoAck ;Clear error flags. 0029 C201 90 CLR Fault 002B C202 91 CLR Retry 002D 85812D 92 VOM StackSave, SP ;Save stack address for bus fault. 0030 E523 93 MOV A,SlvAdr ;Get slave address. 0032 310C 94 ACALL SendAddr ;Get bus and send slave addr. 0034 200012 95 JB NoAck, SDEX ;Check for missing ; acknowledge. 0037 200112 96 ;Check for bus fault. JB Fault, SDatErr 003A 7829 97 VOM R0, #XmtDat ;Set start of transmit ; buffer. 98 003C E6 99 SDLoop: VOM A, @RO ;Get data for slave. 003D 08 100 INC 003E 3125 101 ACALL XmitByte ; Send data to slave. 0040 200006 102 JB NoAck, SDEX ;Check for missing ; acknowledge. 0043 200106 103 JB Fault, SDatErr ; Check for bus fault. 0046 D522F3 104 DJNZ ByteCnt, SDLoop 105 0049 3166 106 SDEX: ACALL SendStop ;Send an I2C stop. 004B 22 107 RET 108 109 110 ; Handle a transmit bus fault. 111 SDatErr: AJMP Recover 004C 218A 112 ;Attempt bus recovery. 113 114 115 ; Receive data byte(s) from slave. ; Enter with slave address in SlvAdr, ; # of data bytes requested in ByteCnt. ; Data returned in RcvDat buffer. 117 ``` AN422 | | 118 | | | | | |-------------|-----|------------|----------|------------------|-----------------------------------------| | 004E C200 | 119 | RcvData: | CLR | NoAck | ;Clear error flags. | | 0050 C201 | 120 | | CLR | Fault | | | 0050 C201 | 121 | | CLR | Retry | | | 0054 85812D | 122 | | | StackSave, SP | ;Save stack address<br>; for bus fault. | | 0057 E523 | 123 | | MOV | A,SlvAdr | ;Get slave address. | | | 124 | | SETB | ACC.0 | ;Set bus read bit. | | 0059 D2E0 | 125 | | ACALL | SendAddr | ;Send slave address. | | 005B 310C | 126 | | JB | NoAck, RDEX | ;Check for missing | | 005D 200023 | | | | | ; acknowledge. | | 0060 200123 | 127 | | JB | Fault,RDatErr | ;Check for bus fault. | | | 128 | | | | | | 0063 7825 | 129 | | MOV | R0, #RcvDat | ;Set start of receive ; buffer. | | 0065 D52202 | 130 | | DJNZ | ByteCnt, RDLoop | ;Check for count = 1 ; byte only. | | 0068 800A | 131 | | SJMP | RDLast | | | 0008 800A | 132 | | 55111 | T.D.L.G.D.G | | | 006A 3143 | 133 | RDLoop: | ACALL | RDAck | ;Get data and send | | 006A 3143 | 133 | RDDOOD. | ACADD | ROMOR | ; an acknowledge. | | 0060 200117 | 134 | | JB | Fault, RDatErr | ;Check for bus fault. | | 006C 200117 | 134 | | MOV | @RO,A | ;Save data. | | 006F F6 | | | INC | RO RO | /Bave data: | | 0070 08 | 136 | | DJNZ | ByteCnt, RDLoop | Repeat until last | | 0071 D522F6 | 137 | | DONZ | Бусесис, коноор | ; byte. | | | 138 | | | | Oct lock data busha | | 0074 314F | 139 | RDLast: | ACALL | RcvByte | ;Get last data byte | | | | | | | ; from slave. | | 0076 20010D | 140 | | JB | Fault,RDatErr | ;Check for bus<br>; fault. | | 0079 F6 | 141 | | MOV | @RO,A | ;Save data. | | | 142 | | | | | | 007A 759980 | 143 | | MOV | I2DAT,#80h | ;Send negative | | | | | | | ; acknowledge. | | 007D 309EFD | 144 | | JNB | ATN,\$ | ;Wait for NAK sent. | | 0080 309D03 | 145 | | JNB | DRDY,RDatErr | ;Check for bus | | | | | | | ; fault. | | | 146 | | | | | | 0083 3166 | 147 | RDEX: | ACALL | SendStop | ;Send an I2C bus | | | | | | | ; stop. | | 0085 22 | 148 | | RET | | | | | 149 | | | | | | | 150 | | | | | | | 151 | : Handle a | receive | bus fault. | | | | 152 | , | | | | | 0086 218A | 153 | RDatErr: | AJMP | Recover | ;Attempt bus recovery | | 0000 22011 | 154 | | | | | | | 155 | | | | | | | 156 | · Send dat | a hytel | s) to slave with | subaddress. | | | 157 | , Sena dat | th clave | e address in ACC | subaddress in | | | 13, | | | tes to send in B | | | | 158 | ; data in | | | , 5555, | | | 159 | , data in | | | | | 0000 0200 | | SendSub: | CLR | NoAck | ;Clear error flags. | | 0088 C200 | 160 | sendado: | CLR | Fault | , crear crior rrags. | | 008A C201 | 161 | | | | | | 008C C202 | 162 | | CLR | Retry | ;Save stack address | | 008E 85812D | 163 | | MOV | StackSave, SP | ; for bus fault. | | 0091 E523 | 164 | | MOV | A,SlvAdr | ;Get slave address. | | 0093 310C | 165 | | ACALL | SendAddr | ;Get bus and send | | | | | | | ; slave address. | 77 | 0095 | 20001C | 166 | | JB | NoAck, SSEX | ;Check for missing ; acknowledge. | |------|--------|------------|--------------|-----------|------------------|-----------------------------------------| | 0098 | 20011C | 167 | | JB | Fault,SSubErr | ; Check for bus | | | | | | | | ; fault. | | | | 168 | | | | | | | E524 | 169 | | MOV | A, SubAdr | Get slave subaddress. | | | 3125 | 170 | | ACALL | XmitByte | ;Send subaddress. | | 009F | 200012 | 171 | | JB | NoAck, SSEX | ;Check for missing ; acknowledge. | | 00A2 | 200112 | 172 | | JB | Fault, SSubErr | ;Check for bus fault. | | | 7829 | 173 | | MOV | R0, #XmtDat | ;Set start of | | | | 174 | | | Tro, manesac | ; transmit buffer. | | 00A7 | E6 | | CCT | WOLL | . 000 | | | 00A7 | | 175 | SSLoop: | MOV | A,@RO | ;Get data for slave. | | | | 176 | | INC | R0 | | | | 3125 | 177 | | ACALL | XmitByte | ;Send data to slave. | | 00AB | 200006 | 178 | | JB | NoAck, SSEX | ;Check for missing ; acknowledge. | | 00AE | 200106 | 179 | | JB | Fault, SSubErr | ;Check for bus fault. | | 00B1 | D522F3 | 180 | | DJNZ | ByteCnt, SSLoop | | | | | 181 | | | | | | 00B4 | 3166 | 182 | SSEX: | ACALL | SendStop | ;Send an I2C stop. | | 00B6 | | 183 | | RET | condcop | , bend an 12c stop. | | | | 184 | | | | | | | | 185 | | | | | | | | 186 | · Wandle a | +*** | t bus fault | | | | | | ; nandre a | Cransmi | t bus fault. | | | 0007 | 218A | 187 | CC - b Floor | 1 TMD | <b>5</b> - 1 - 1 | | | 0067 | 210A | 188 | SSubErr: | AJMP | Recover | ;Attempt bus recovery. | | | | 189 | | | | | | | | 190 | _ | | | | | | | 191 | | | | with subaddress. | | | | 192 | | | | Adr, subaddress in SubAdr, | | | | | | | requested in By | yteCnt. | | | | 193<br>194 | ; Data ret | urned in | RcvDat buffer. | | | ОПРО | C200 | | Des-Gb | GT D | | | | | | 195 | RcvSub: | CLR | NoAck | ;Clear error flags. | | | C201 | 196 | | CLR | Fault | | | | C202 | 197 | | CLR | Retry | | | | 85812D | 198 | | MOV | StackSave, SP | ;Save stack address<br>; for bus fault. | | 00C2 | E523 | 199 | | MOV | A,SlvAdr | ;Get slave address. | | 00C4 | 310C | 200 | | ACALL | SendAddr | ;Send slave address. | | 00C6 | 20003E | 201 | | JB | NoAck, RSEX | ;Check for missing | | | | | | | | ; acknowledge. | | 00C9 | 20013E | 202<br>203 | | JB | Fault, RSubErr | ;Check for bus fault. | | 00CC | E524 | 204 | | MOV | A, SubAdr | ;Get slave subaddress. | | 00CE | 3125 | 205 | | ACALL | XmitByte | ;Send subaddress. | | 0000 | 200034 | 206 | | JB | NoAck, RSEX | ;Check for missing | | 00D3 | 200134 | 207 | | JB | Fault Doubes- | ; acknowledge. | | | | 208 | | CD. | Fault, RSubErr | ;Check for bus fault. | | 00D6 | 317A | 209 | | ACALL | RepStart | .Cond monasted at- | | | 20012F | 210 | | | | ;Send repeated start. | | | E523 | 211 | | JB<br>MOV | Fault, RSubErr | Check for bus fault. | | | D2E0 | | | MOV | A,SlvAdr | ;Get slave address. | | | | 212 | | SETB | ACC.0 | ;Set bus read bit. | | | 3115 | 213 | | ACALL | SendAd2 | ;Send slave address. | | | 200023 | 214 | | JB | NoAck, RSEX | ;Check for missing ; acknowledge. | | 00E4 | 200123 | 215 | | JB | Fault,RSubErr | ;Check for bus fault. | | | | 216 | | | | | | 00E7 | 7825 | 217 | | MOV | R0, #RcvDat | ;Set start of ; receive buffer. | | ೧೧೯೪ | | | | | | , recetae partet. | | 0011 | D52202 | 218 | | DJNZ | ByteCnt, RSLoop | ;Check for count = 1<br>; byte only. | | 0 | 0EC | 800A | 219 | | SJMP | RSLast | | | |----|----------|--------|-----|---------------------------------|-----------|------------------|-------------------------|-------------------| | | | | 220 | | | | | | | 01 | 0EE | 3143 | 221 | RSLoop: | ACALL | RDAck | ;Get data<br>; an ackno | | | 0 | 0F0 | 200117 | 222 | | JB | Fault, RSubErr | ;Check for | bus fault. | | 0 | 0F3 | F6 | 223 | | VOM | @RO,A | ;Save data | • | | 0 | 0F4 | 0.8 | 224 | | INC | R0 | | | | | | D522F6 | 225 | | DJNZ | ByteCnt, RSLoop | ·Reneat un | til last byte | | 0 | UFJ | DJZZFO | | | DONE | Буссене, кыноор | /Repeat an | cii idae ayee. | | _ | | | 226 | | | | a . 1 | 47.1 | | 0 | OF8 | 314F | 227 | RSLast: | ACALL | RcvByte | ;Get last<br>; from sla | | | 0 | 0FA | 20010D | 228 | | JB | Fault, RSubErr | ;Check for | bus fault. | | 0 | 0FD | F6 | 229 | | MOV | @RO,A | ;Save data | | | | | | 230 | | | | | | | Λ | معد | 759980 | 231 | | MOV | I2DAT,#80h | ;Send nega | tive | | 0 | OLE | 733360 | 231 | | HOV | IZDAI, WOOM | ; acknowle | | | | | | | | | | | _ | | | | 309EFD | 232 | | JNB | ATN,\$ | ;Wait for | | | 0 | 104 | 309D03 | 233 | | JNB | DRDY,RSubErr | ;Check for | bus fault. | | | | | 234 | | | | | | | 0 | 107 | 3166 | 235 | RSEX: | ACALL | SendStop | ;Send an I | 2C bus stop. | | 0 | 109 | 22 | 236 | | RET | | | | | • | 100 | 22 | 237 | | 1122 | | | | | | | | | | | | | | | | | | 238 | | | | | | | | | | 239 | ; Handle a | receive | bus fault. | | | | | | | 240 | | | | | | | 0 | 10A | 218A | 241 | RSubErr: | AJMP | Recover | ;Attempt b | ous recovery. | | | | | 242 | | | | _ | · | | | | | 243 | | | | | | | | | | | | | ****** | | | | | | | 244 | , , , , , , , , , , , , , , , , | | | | | | | | | 245 | ; | | Subroutines | | | | | | | 246 | ;****** | ***** | ****** | ****** | ****** | | | | | 247 | | | | | | | | | | 248 | ; Send add | lress byt | ce. | | | | | | | 249 | | | ress in ACC. | | | | | | | 250 | , | | | | | | _ | 100 | EED0E0 | | 0 32 33 | MOTT | TOORG #PMPO.PM | TD - CONTACT | Parings TOC hus | | | | 75D852 | 251 | SendAddr: | MOV | I2CFG, #BMRQ+BT | IR+CTVAL | ;Request I2C bus. | | 0 | 10F | 309EFD | 252 | | JNB | ATN,\$ | | ;Wait for bus | | | | | | | | | | ; granted. | | 0 | 112 | 309908 | 253 | | JNB | Master,SAErr | | ;Should have | | | | | | | | | | ; become the bus | | | | | | | | | | ; master. | | 0 | 1115 | F599 | 254 | SendAd2: | MOV | I2DAT, A | | ;Send first bit, | | | 1110 | FJJJ | 234 | Bellanaz. | MOV | IZDAI,A | | | | | | | | | | | | ; clears DRDY. | | 0 | 117 | 75981C | 255 | | VOM | I2CON, #BCARL+B | CSTR+BCSTP | | | | | | | | | | | ; releases SCL. | | C | 11A | 3120 | 256 | | ACALL | XmitAddr | | ;Finish sending | | | | | | | | | | ; address. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | C | )11C | 22 | 257 | | RET | | | | | | | | 258 | | | | | | | C | )11D | D201 | 259 | SAErr: | SETB | Fault | | ;Return bus fault | | | | | | | | | | ; status. | | _ | )11F | 22 | 260 | | RET | | | , | | | ) T T.T. | 22 | | | KILL | | | | | | | | 261 | | | | | | | | | | 262 | | | | | | | | | | 263 | ; Byte tra | ansmit r | outine. | | | | | | | 264 | ; Enter | with da | ta in ACC. | | | | | | | 265 | | | ansmits 8 bits. | | | | | | | 266 | | | ansmits 7 bits ( | for address | s only) | | | | | | , AULTON | AUL : LE | anamita / Dics ( | LOI AUGIES | S CHILY / . | | | | | 267 | | | | | <b>=</b> 11. | | ( | )120 | 752108 | 268 | XmitAddr: | MOV | BitCnt,#8 | | 7 bits of | | | | | | | | | ; add | dress count. | | ( | 123 | 8005 | 269 | | SJMP | XmBit2 | | | | | | | 270 | | | | | | | | | | - | | | | | | | 0125 | 752108 | 271 | XmitByte: | MOV | BitCnt,#8 | ;Set 8 bits of data ; count. | |--------------|--------|-----|------------|----------|-----------------------|-----------------------------------------| | 0128 | F599 | 272 | XmBit: | MOV | I2DAT, A | ;Send this bit. | | 012A | 23 | 273 | XmBit2: | RL | A | Get next bit. | | | 309EFD | 274 | | JNB | ATN,\$ | ;Wait for bit sent. | | | 309D0F | 275 | | JNB | DRDY, XMErr | ;Should be data ready. | | | D521F4 | 276 | | DJNZ | BitCnt, XmBit | ;Repeat until all bits sent. | | 0134 | 7598A0 | 277 | | MOV | I2CON, #BCDR+BCXA | ;Switch to | | | | | | | Incom, "Beble Bern! | ; receive mode. | | 0137 | 309EFD | 278 | | JNB | ATN,\$ | ;Wait for acknowledge | | 013 <u>a</u> | 309F02 | 279 | | JNB | DDAM VMDV | ; bit. | | | D200 | 280 | | | RDAT, XMBX | ;Was there an ack? | | 0130 | D200 | 200 | | SETB | NoAck | ;Return no acknowledge<br>; status. | | 013F | 22 | 281 | XMBX: | RET | | , scacus. | | | | 282 | | | | | | 0140 | D201 | 283 | XMErr: | SETB | Fault | ;Return bus fault | | | | | | 0212 | 14410 | ; status. | | 0142 | 22 | 284 | | RET | | , beacus. | | | | 285 | | | | | | | | 286 | | | | | | | | 287 | ; Byte rec | eive rou | tines | | | | | 288 | ; RDAck | | eives a byte of data, | thon gonda | | | | 200 | | nowledge | | chen senas | | | | 289 | | | eives a byte of data. | | | | | 290 | | eturned | | | | | | 291 | , Data I | ecurneu | III ACC. | | | 0143 | 31/F | 292 | RDAck: | ACALL | BorrPort o | Paradan a data base | | | 759900 | 293 | NDACK. | MOV | RcvByte | Receive a data byte. | | 0143 | 733300 | 293 | | MOV | I2DAT,#0 | ;Send receive | | 0148 | 309EFD | 294 | | JNB | ATN,\$ | ; acknowledge.<br>;Wait for acknowledge | | 0140 | 309D15 | 205 | | TATO | pppy p lp | ; sent. | | 014B | | 295 | | JNB | DRDY, RdErr | ;Check for bus fault. | | 0146 | 22 | 296 | | RET | | | | 0145 | 750100 | 297 | | | | | | | 752108 | 298 | RcvByte: | MOV | BitCnt,#8 | ;Set bit count. | | 0152 | | 299 | | CLR | A | ;Init received byte ; to 0. | | 0153 | 4599 | 300 | RBit: | ORL | A, I2DAT | ;Get bit, clear ATN. | | 0155 | 23 | 301 | | RL | A | ;Shift data. | | 0156 | 309EFD | 302 | | JNB | ATN,\$ | ;Wait for next bit. | | 0159 | 309D07 | 303 | | JNB | DRDY, RdErr | ;Should be data ready. | | 015C | D521F4 | 304 | | DJNZ | BitCnt,RBit | ;Repeat until 7 bits | | | | | | | | ; are in. | | 015F | A29F | 305 | | MOV | C, RDAT | ;Get last bit, don't | | | | | | | | ; clear ATN. | | 0161 | | 306 | | RLC | A | ;Form full data byte. | | 0162 | 22 | 307 | | RET | | | | | | 308 | | | | | | 0163 | | 309 | RdErr: | SETB | Fault | ;Return bus fault status. | | 0165 | 22 | 310 | | RET | | | | | | 311 | | | | | | | | 312 | | | | | | | | 313 | ; I2C stop | routine | • | | | | | 314 | | | | | | 0166 | C2DE | 315 | SendStop: | CLR | MASTRQ | ;Release bus | | 01 | TE0001 | | | | | ; mastership. | | | 759821 | 316 | | VOM | I2CON, #BCDR+BXSTP | ;Generate a bus stop. | | | 309EFD | 317 | | JNB | ATN,\$ | ;Wait for atn. | | | 759820 | 318 | | VOM | I2CON, #BCDR | ;Clear data ready. | | | 309EFD | 319 | | JNB | ATN,\$ | ;Wait for stop sent. | | | 759894 | 320 | | VOM | I2CON, #BCARL+BCSTP+E | BCXA ;Clear I2C bus. | | 0177 | | 321 | | CLR | TIRUN | ;Stop timer I. | | 0179 | 22 | 322 | | RET | | | | | | 323 | | | | | | | | | | | | | | | | 324 | | | | | |-------|-----------|-----|------------|-----------|---------------------|---------------------------| | | | 325 | · T2C rene | ated sta | rt routine. | | | | | 326 | _ | | ress in ACC. | | | | | 327 | , Direct | WICH GGG | 1100. | | | 0177 | 750000 | 328 | BonCtort. | MOV | I2CON, #BCDR+BXSTR | ;Send repeated start. | | | 759822 | | RepStart: | | | ;Wait for ATN. | | | 309EFD | 329 | | JNB | ATN,\$ | | | | 759820 | 330 | | VOM | I2CON, #BCDR | ;Clear data ready. | | 0183 | 309EFD | 331 | | JNB | ATN,\$ | ;Wait for repeated | | | | | | | | ; start sent. | | 0189 | 9 22 | 333 | | RET | | | | | | 334 | | | | | | | | 335 | | | | | | | | 336 | ; Bus faul | t recove | ery routine. | | | | | 337 | | | | | | 0182 | A 31A4 | 338 | Recover: | ACALL | FixBus | ;See if bus is dead or | | | | | | | | ; can be 'fixed'. | | 0180 | C 400D | 339 | | JC | BusReset | ;If not 'fixed', try | | | | | | | | ; extreme measures. | | 018 | E D202 | 340 | | SETB | Retry | ; If bus OK, return to | | 010 | L DECE | 340 | | 0212 | 1.001, | ; main routine. | | 010 | 0 0001 | 341 | | CLR | Fault | , main routine. | | | 0 C201 | | | | | | | | 2 C200 | 342 | | CLR | NoAck | | | | 4 D2DD | 343 | | SETB | CLRTI | mushin adams. T | | | 6 D2DC | 344 | | SETB | TIRUN | Enable timer I. | | 019 | 8 D2AB | 345 | | SETB | ETI | ;Turn on timer I | | | | | | | | ; interrupts. | | 019. | A 22 | 346 | | RET | | | | | | 347 | | | | | | | | 348 | ;This rou | tine tri | es a more extreme m | ethod of bus recovery. | | | | 349 | ; This is | used if | SCL or SDA are stu- | ck and cannot | | | | | ; otherwis | se be fre | eed. | | | | | 350 | ; (will re | eturn to | the Recover routin | e when Timer I times out) | | | | 351 | | | | | | 019 | B C2DE | 352 | BusReset: | CLR | MASTRQ | ;Release bus. | | | D 7598BC | 353 | | MOV | I2CON,#0BCh | ;Clear all I2C flags. | | | 0 D2DC | 354 | | SETB | TIRUN | | | | 2 80FE | 355 | | SJMP | \$ | ;Wait for timer I | | 0 111 | 2 0012 | | | | | ; timeout (this will re- | | | | 356 | | | | ; set the I2C hardware). | | | | 357 | | | | , bee the 120 hardware, | | | | | | | | | | | | 358 | . mb.a. wa | utino ot | tomata to rogain do | ntrol of the TCC | | | | 359 | | utine at | tempts to regain co | | | | | | <i>;</i> | | bus after a bus fa | uic. | | | | | | | | 16611 | | | | 360 | ; Return | s carry | clear if successful | , carry set if failed. | | | | 361 | | | | | | | 4 C2DE | 362 | FixBus: | CLR | MastRQ | ;Turn off I2C functions. | | 01A | .6 D3 | 363 | | SETB | C | | | 01A | 7 D280 | 364 | | SETB | SCL | ;Insure I/O port is not | | | | | | | | ; locking I2C. | | 01A | 9 D281 | 365 | | SETB | SDA | | | 01A | B 308029 | 366 | | JNB | SCL, FixBusEx | ; If SCL is low, bus | | | | | | | | ; cannot be 'fixed'. | | 012 | E 208113 | 367 | | JB | SDA, RStop | ; If SCL & SDA are high, | | 0 11 | L 200113 | 50, | | | | ; force a stop. | | 015 | 31 752109 | 368 | | MOV | BitCnt,#9 | ;Set max # of tries to | | OIL | 1 /32109 | 300 | | MOV | Втеспе, #9 | | | 01- | 4 6202 | 360 | Chalar | OT D | CCI | ; clear bus. | | | 34 C280 | 369 | ChekLoop: | | SCL | ;Force an I2C clock. | | | 36 31D8 | 370 | | ACALL | SDelay | 11 | | | 38 208109 | 371 | | JB | SDA, RStop | ;Did it work? | | 011 | BB D280 | 372 | | SETB | SCL | | | | 3D 31D8 | 373 | | ACALL | SDelay | | | 01E | BF D521F2 | 374 | | DJNZ | BitCnt,ChekLoop | ;Repeat clocks until | | | | | | | | ; either SDA clears or | | | | 375 | | | | ; we run out of tries. | | | | | | | | | AN422 | 01C2 801 | .3 | | 376 | | SJMP | FixBusEx | ;Failed to fix bus by | |----------|-------|--|-----|-----------------------|----------|-------------------|-----------------------------| | | | | 200 | | | | ; this method. | | 0101 000 | | | 377 | Date | GT D | an. | | | 01C4 C28 | 31 | | 378 | RStop: | CLR | SDA | Try forcing a stop | | | | | | | | | ; since SCL & SDA | | 01C6 31I | | | 379 | | ACALL | SDelay | ; are both high. | | 01C8 D28 | | | 380 | | SETB | SCL | | | 01CA 31I | | | 381 | | ACALL | SDelay | | | 01CC D28 | 31 | | 382 | | SETB | SDA | | | 01CE 31I | 8 | | 383 | | ACALL | SDelay | | | 01D0 308 | 3004 | | 384 | | JNB | SCL, FixBusEx | ;Are SCL & SDA still | | | | | | | | | ; high? If so, assume bus | | 01D3 308 | 3101 | | 385 | | JNB | SDA, FixBusEx | ; is now OK, and return | | 01D6 C3 | | | 386 | | CLR | С | ; with carry cleared. | | 01D7 22 | | | 387 | FixBusEx: | RET | | | | | | | 388 | | | | | | | | | 389 | | | | | | | | | 390 | ; Short de | lav rout | ine (10 machine | cvcles). | | | | | 391 | | - | | | | 01D8 00 | | | 392 | SDelay: | NOP | | | | 01D9 00 | | | 393 | | NOP | | | | 01DA 00 | | | 394 | | NOP | | | | 01DB 00 | | | 395 | | NOP | | | | 01DB 00 | | | 396 | | NOP | | | | | | | | | | | | | 01DD 00 | | | 397 | | NOP | | | | 01DE 00 | | | 398 | | NOP | | | | 01DF 00 | | | 399 | | NOP | | | | 01E0 22 | | | 400 | | RET | | | | | | | 401 | | | | | | | | | 402 | • | ****** | | ******* | | | | | 404 | ; | | Main Program | | | | | | 405 | ; * * * * * * * * * * | ****** | ****** | ****** | | | | | 406 | | | | | | 01E1 758 | 3107 | | 407 | Reset: | VOM | SP,#07h | ;Set stack location. | | 01E4 D2 | AΒ | | 408 | | SETB | ETI | ;Enable timer I interrupts. | | 01E6 D2 | ΑF | | 409 | | SETB | EA | ;Enable global interrupts. | | 01E8 752 | 290B | | 410 | | MOV | XmtDat,#11 | ;Set up transmit data. | | 01EB 752 | 2A16 | | 411 | | MOV | XmtDat+1,#22 | ;Set up transmit data. | | 01EE 752 | B2C | | 412 | | MOV | XmtDat+2,#44 | ;Set up transmit data. | | 01F1 752 | 2C58 | | 413 | | MOV | XmtDat+3,#88 | ;Set up transmit data. | | 01F4 752 | 2500 | | 414 | | MOV | RcvDat,#0 | ;Clear receive data. | | 01F7 752 | 2600 | | 415 | | MOV | RcvDat+1,#0 | ;Clear receive data. | | 01FA 752 | 2700 | | 416 | | MOV | RcvDat+2,#0 | ;Clear receive data. | | 01FD 752 | | | 417 | | MOV | RcvDat+3,#0 | ;Clear receive data. | | | | | 418 | | | | , ====== | | 0200 752 | 2348 | | 419 | MainLoop: | MOV | SlvAdr,#48h | ;Set slave address | | 0200 /3. | | | | marine op. | 1101 | D111101 / 11 1011 | ; (8-bit I/O port). | | 0203 752 | 2201 | | 420 | | MOV | ByteCnt,#1 | ;Set up byte count. | | 0206 112 | | | 421 | | ACALL | SendData | | | 0208 200 | | | 422 | | JB | | ;Send data to slave. | | 0208 200 | JZF J | | 423 | | UD | Retry, MainLoop | | | 020B 752 | 201 | | 424 | ML2: | MOV | D | | | 020E 732 | | | 425 | MLZ: | | ByteCnt,#1 | ;Set up byte count. | | | | | | | ACALL | RcvData | ;Read data from slave. | | 0210 200 | )ZF.8 | | 426 | | JB | Retry,ML2 | | | | | | 427 | | | | | | 0213 752 | 23A0 | | 428 | SL1: | MOV | SlvAdr,#0A0h | ;Set slave address | | | | | | | | | ; (RAM chip). | | 0216 752 | | | 429 | | MOV | SubAdr,#0h | ;Set slave subaddress. | | 0219 752 | | | 430 | | VOM | ByteCnt,#4 | ;Set up byte count. | | 021C 118 | 38 | | 431 | | ACALL | SendSub | | | 021E 200 | )2F2 | | 432 | | JB . | Retry, SL1 | | | | | | 433 | | | | | | | | | | | | | | September 1989 82 | 0221 752204 | 434 SL2: | MOV ByteCnt,#4 | ;Set up byte count. | |--------------------------|-------------|-------------------------|---------------------| | 0221 /52204<br>0224 11B9 | 434 5112: | ACALL RevSub | , see up sie count. | | 0224 11B3<br>0226 2002F8 | 436 | JB Retry, SL2 | | | OZZO ZOOZFO | 437 | ob Recry, one | | | 0229 0529 | 438 | INC XmtDat | | | 0229 0529<br>022B 052A | 439 | INC XmtDat+1 | | | 022B 052B<br>022D 052B | 440 | INC XmtDat+2 | | | 022F 052C | 441 | INC XmtDat+3 | | | 0231 80CD | 442 | SJMP MainLoop | ;Do it all again. | | | 443 | | | | | 444 | ENDASSEMBLY COMPLETE | 0 ERRORS FOUND | | | | | | | | | ter I2C Routines | | | ACC | | D ADDR 00E0H PREDEFINED | | | ATN | | B ADDR 009EH PREDEFINED | | | BCARL | | NUMB 0010H | | | BCDR | | NUMB 0020H | | | BCSTP | | NUMB 0004H | | | BCSTR | | NUMB 0008H | | | BCXA | | NUMB 0080H | | | BIDLE | | NUMB 0040H NOT USED | | | BITCNT | | D ADDR 0021H | | | BMRQ | | NUMB 0040H | | | BTIR | | NUMB 0010H | | | BUSRESET | | C ADDR 019BH | | | BXSTP | | NUMB 0001H | | | BXSTR | | NUMB 0002H | | | BYTECNT | | D ADDR 0022H | | | CHEKLOOP | | C ADDR 01B4H | | | CLRINT | | C ADDR 0026H | | | CLRTI | | B ADDR 00DDH PREDEFINED | | | CTVAL | | NUMB 0002H | | | DRDY | | B ADDR 009DH PREDEFINED | | | EA | | B ADDR 00AFH PREDEFINED | | | | | B ADDR 00ABH PREDEFINED | | | FAULT | | B ADDR 0001H | | | FIXBUS | | C ADDR 01A4H | | | FIXBUSEX | | C ADDR 01D7H | | | FLAGS | | D ADDR 0020H | | | I2CFG | | D ADDR 00D8H PREDEFINED | | | I2CON | | D ADDR 0098H PREDEFINED | | | I2DAT | | D ADDR 0099H PREDEFINED | | | MAINLOOP | | C ADDR 0200H | | | MASTER | | B ADDR 0099H PREDEFINED | | | MASTRQ | | B ADDR 00DEH PREDEFINED | | | ML2 | | C ADDR 020BH | | | NOACK | | B ADDR 0000H | | | PO | | D ADDR 0080H PREDEFINED | | | RBIT | | C ADDR 0153H | | | RCVBYTE | | C ADDR 014FH | | | RCVDAT | | D ADDR 0025H | | | RCVDATA | | C ADDR 004EH | | | RCVSUB | | C ADDR 00B9H | | | RDACK | | C ADDR 0143H | | | RDAT | | B ADDR 009FH PREDEFINED | | | RDATERR | | C ADDR 0086H | | | RDERR | | C ADDR 0163H | | | RDEX | | C ADDR 0103H | | | RDLAST | | C ADDR 0003H | | | | | C ADDR 0074H | | | RDLOOP | | | | | RECOVER | • • • • • • | C ADDR 017AH | | | | | | | | | | C ADDR 01E1H | | | RETRY | | | | | NOEA | | C ADDR 0107H | | | | | | | | RSLAST . | | | | | | | | | | | ٠. | | C ADDR | 00F8H | | |----------|----|---|-----|----|----|----|----|----|---|----|----|----|--------|-------|------------| | RSLOOP . | | | | ٠. | | | | | | | | | C ADDR | 00EEH | | | RSTOP | | | | | | | ٠. | | | | | | C ADDR | 01C4H | | | RSUBERR. | | | | | | | | | | | | | C ADDR | 010AH | | | SAERR | | | | | | | | | | | | | C ADDR | 011DH | | | SCL | | | | | | | | ٠. | | | | | B ADDR | 0080н | | | SDA | | | | | | | | | | | | | B ADDR | 0081H | | | SDATERR. | | | | | | | | | | | | | C ADDR | 004CH | | | SDELAY . | ٠. | | | | | | | | | | | ٠. | C ADDR | 01D8H | | | SDEX | | | | | ٠. | | | | | | | ٠. | C ADDR | 0049H | | | SDLOOP . | | | ٠. | | | | | | | | | | C ADDR | 003CH | | | SENDAD2. | | | | | | | | | | | | | C ADDR | 0115H | | | SENDADDR | | | | | | | | | | ٠. | | | C ADDR | 010CH | | | SENDDATA | | | | | | | | | | | | | C ADDR | 0027H | | | SENDSTOP | | | | | ٠ | ٠. | | | | | | | C ADDR | 0166H | | | SENDSUB. | • | | | | | | | | | | •, | | C ADDR | 0088н | | | SL1 | | | | | | | | | | | | | C ADDR | 0213H | | | SL2 | | | | • | | | | | | | | | C ADDR | 0221H | | | SLVADR . | | | | | | | • | | | | | | D ADDR | 0023H | | | SP | | | | | | | • | | | | | | D ADDR | 0081H | PREDEFINED | | SSEX | ٠ | | | | | | | ٠ | | | | | C ADDR | 00B4H | | | SSLOOP . | | | | | | | | | | | | | C ADDR | 00A7H | | | SSUBERR. | ٠ | • | | | | | | | | | | | C ADDR | 00B7H | | | STACKSAV | Ε. | | | | • | | | | | | | | D ADDR | 002DH | | | SUBADR . | | ٠ | • | ٠ | • | | • | | | • | | | D ADDR | 0024H | | | TIMERI . | ٠ | ٠ | | • | • | | | | | | | | C ADDR | 001BH | NOT USED | | TIRUN | | | ٠ | | ٠. | | | | | | | | B ADDR | 00DCH | PREDEFINED | | XMBIT | | | • | | | | - | | | | | | C ADDR | 0128H | | | XMBIT2 . | | | . • | | | | | | | | | | C ADDR | 012AH | | | XMBX | | | | | | | • | | | | | | C ADDR | 013FH | | | XMERR | • | ٠ | | ٠ | ٠ | | | | | ٠ | | | C ADDR | 0140H | | | XMITADDR | • | | • | | | ٠ | ٠. | | | | | | C ADDR | 0120H | | | XMITBYTE | ٠ | | ٠ | | | | | | | | | | C ADDR | 0125H | | | XMTDAT . | | ٠ | | | • | • | | | • | | | | D ADDR | 0029Н | | | | | | | | | | | | | | | | | | | Philips Semiconductors Application note ### Interfacing the PCD8584 I<sup>2</sup>C-bus controller to 80C51 family microcontrollers **AN425** #### DESCRIPTION This application note shows how to use the PCD8584 I<sup>2</sup>C-bus controller with 80C51 family microcontrollers. One typical way of connecting the PCD8584 to an 80C31 is shown. Some basic software routines are described showing how to transmit and receive bytes in a single master system. An example is given of how to use these routines in an application that makes use of the I<sup>2</sup>C circuits on an I<sup>2</sup>C demonstration board. The PCD8584 is used to interface between parallel microprocessor or microcontroller buses and the serial I<sup>2</sup>C bus. For a description of the I<sup>2</sup>C bus protocol refer to the I<sup>2</sup>C bus specification which is printed in the microcontroller user guide. The PCD8584 controls the transmission and reception of data on the I<sup>2</sup>C bus, arbitration, clock speeds and transmission and reception of data on the parallel bus. The parallel bus is compatible with 80C51, 68000, 8085 and Z80 buses. Communication with the I<sup>2</sup>C-bus can be done on an interrupt or polled basis. This application note focuses on interfacing with 8051 microcontrollers in single master systems. #### PCD8584 In Figure 1, a block diagram is shown of the PCD8584. Basically it consists of an 1<sup>2</sup>C-interface similar to the one used in 84Cxx family microcontrollers, and a control block for interfacing to the microcontroller. The control block can automatically determine whether the control signals are from 80xx or 68xxx type of microcontrollers. This is determined after the first write action from the microcontroller to the PCD-8584. The control block also contains a programmable divider which allows the selection of different PCD8584 and I<sup>2</sup>C clocks The I<sup>2</sup>C interface contains several registers which can be written and read by the microcontroller. S1 is the control/status register. This register is accessed while the A0 input is 1. The meaning of the bits depends on whether the register is written to or read from. When used as a single master system the following bits are important: PIN: Interrupt bit. This bit is made active when a byte is sent/received to/from the I<sup>2</sup>C-bus. When ENI is made active, PIN also controls the external INT line to interrupt the microcontroller. **ES0-ES2:** These bits are used as pointer for addressing S0, S0', S2 and S3. Setting ES0 also enables the Serial I/O. **ENI:** Enable Interrupt bit. Setting this bit enables the generation of interrupts on the INT line. **STA, STO:** These bits allow the generation of START or STOP conditions. ACK: With this bit set and the PCD8584 is in master/receiver mode, no acknowledge is generated by the PCD8584. The slave/transmitter now knows that no more data must be sent to the I<sup>2</sup>C-bus. **BER:** This bit may be read to check if bus errors have occurred. **BB:** This bit may be read to check whether the bus is free for I<sup>2</sup>C-bus transmission. S2 is the clock register. It is addressed when A0 = 0 and ES0-ES2 = 010 in the previous write cycle to S1. With the bits S24-S20 it is possible to select 5 input clock frequencies and 4 $1^2$ C clock frequencies. S3 is the interrupt vector register. It is addressed when A0 = 0 and ES0-ES2 = 001 in the previous write cycle to S1. This register is not used when an 80C51 family orcontroller is used. An 80C51 microcontroller has fixed interrupt vector addresses. S0' is the own address register. It is addressed when A0 = 0 and ES0-ES2 = 000. This register contains the slave address of the PCD8584. In the single master system described here, this register has no functional use. However, by writing a value to S0', the PCD8584 determines whether an 80Cxx or 68xxx type microcontroller is the controlling microcontroller by looking at the $\overline{CS}$ and $\overline{WR}$ lines. So independent of whether the PCD8584 is used as master or slave, the microcontroller should always first write a value to S0' after reset. S0 is the I<sup>2</sup>C data register. It is addressed when A0 = 0 and ES0-ES2 = 1x0. Transmission of a byte on the I<sup>2</sup>C bus is done by writing this byte to S0. When the transmission is finished, the PIN bit in S1 is reset and if ENI is set, an interrupt will be generated. Reception of a byte is signaled by resetting PIN and by generating an interrupt if ENI is set. The received byte can be read from S0. The SDA and SCL lines have no protection diodes to $V_{\rm DD}$ . This is important for multimaster systems. A system with a PCD8584 can now be switched off without causing the $\rm I^2C$ -bus to hang-up. Other masters still can use the bus. For more information of the PCD8584 refer to the data sheet. #### PCD8584/8031 Hardware Interface Figure 2 shows a minimum system with an 8051 family controller and a PCD8584. In this example, an 80C31 is used. However any 80C51 family controller with external addressing capability can be used. The software resides in EPROM U3. For addressing this device, latch U2 is necessary to demultiplex the lower address bits from the data bits. The PCD8584 is mapped in the external data memory area. It is selected when A1 = 0. Because in this example no external RAM or other mapped peripherals are used, no extra address decoding components are necessary. A0 is used by the PCD8584 for proper register selection in the U5A is an inverter with Schmitt trigger input and is used to buffer the oscillator signal of the microcontroller. Without buffering, the rise and fall time specifications of the CLK signal are not met. It is also important that the CLK signal has a duty cycle of 50%. If this is not possible with certain resonators or microcontrollers, then an extra flip-flop may me necessary to obtain the correct duty cycle. U5C and U5D are used to generate the proper reset signals for the microcontroller and the PCD8584. April 1990 85 Figure 1. PCD8584 Block Diagram AN425 Figure 2. PCD8584 to 80C31 Interface ### Basic PCD8584/8031 Driver Routines In the listing section (page 89), some basic routines are shown. The routines are divided in two modules. The module ROUTINE contains the driver routines and initialization of the PCD8584. The module INTERR contains the interrupt handler. These modules may be linked to a module with the user program that uses the routines in INTERR and ROUTINE. In this application note, this module will be called USER. A description of ROUTINE and INTERR follows. #### **Module ROUTINE** #### Routine Sendbyte (Lines 17-20)— This routine sends the contents of the accumulator to the PCD8584. The address is such that A0 = 0. Which register is accessed depends on the contents of ES0-ES2 of the control register. The address of the PCD8584 is in variable 'PCD8584'. This must have been previously defined in the user program. The DPTR is used as a pointer for addressing the peripheral. If the address is less than 255, then R0 or R1 may be used as the address pointer. #### Routine Sendcontr (Lines 25, 26)— This routine is similar to Sendbyte, except Inis routine is similar to Sendbyte, except that now A0 = 1. This means that the contents of the accumulator are sent to the control register S1 in the PCD8584. #### Routine Readbyte (Lines 30-33)- This routine reads a register in the PCD8584 with A0 = 0. Which register depends on ES0-ES2 of the control register. The result of the read operation is returned in the accumulator. #### Routine Readcontr (Lines 37-39)— This routine is similar to Readbyte, except that now A0 = 1. This means that the accumulator will contain the value of status register S1 of the PCD8584. #### Routine Start Lines (44-56)- This routine generates a START-condition and the slave address with a R/W bit. In line 44, the variable IIC\_CNT is reset. This variable is used as a byte counter to keep track of the number of bytes that are received or transmitted. IIC\_CNT is defined in module INTERR. Lines 45-46 increment the variable NR\_BYTES if the PCD8584 must receive data. NR\_BYTES is a variable that indicates how many bytes have to be received or transmitted. It must be given the correct value in the USER module. Receiving or transmitting is distinguished by the value of Philips Semiconductors Application note ### Interfacing the PCD8584 I<sup>2</sup>C-bus controller to 80C51 family microcontrollers AN425 the DIR bit. This must also be given the correct value in the USER module. Then the status register of PCD8584 must be read to check if the I<sup>2</sup>C bus is free. First the status register must be addressed by giving ES0-ES2 of the control register the correct value (lines 47-49). Then the Bus Busy bit is tested until the bus is free (lines 49-50). If this is the case, the slave address is sent to data register S0 and the I2C\_END bit is cleared (lines 51-53). The slave address is set by the user program in variable USER. The LSB of the slave address is the R/W bit. I2C\_END can be tested by the user program whether an I2C reception/transmission is in progress or not. Next the START condition will be generated and interrupt generation enabled by setting the appropriate bits in control register S1. (lines 54-55). Now the routine will return back to the user program and other tasks may be performed. When the START condition, slave address and R/W bit are sent, and the ACK is received, the PCD8584 will generate an interrupt. The interrupt routine will determine if more bytes have to be received or transmitted. #### Routine Stop (Lines 59-62) --- Calling this routine, a STOP condition will be sent to the I<sup>2</sup>C bus. This is done by sending the correct value to control register S1 (lines 59-61). After this the I2C\_END bit is set, to indicate to the user program that a complete I<sup>2</sup>C sequence has been received or transmitted. #### Routine I2C\_Init (Lines 65-76)- This routine initializes the PCD8584. This must be done directly after reset. Lines 67-70 write data to 'own address' register S0'. First the correct address of S0' is set in control register S1 (lines 67-68), then the correct value is written to it (lines 69-70). The value for S0' is in variable SLAVE\_ADR and set by the user program. As noted previously, register S0' must always be the first register to be accessed after reset, because the PCD8584 now determines whether an 80Cxxx or 68xxx microcontroller is connected. Lines 72-76 set the clock register S2. The variable I2C\_CLOCK is also set by the user program. #### Module INTERR This module contains the I<sup>2</sup>C interrupt routine. This routine is called every time a byte is received or transmitted on the I<sup>2</sup>C bus. In lines 12-15 RAM space for variables is reserved. BASE is the start address in the internal 80C51 RAM where the data is stored that is received, or where the data is stored that has to be transmitted. NR\_BYTES, IIC\_CNT and SLAVE were explained earlier. I2C\_END and DIR are flags that are used in the program. I2C\_END indicates whether an I<sup>2</sup>C transmission or reception is in progress. DIR indicates whether the PCD8584 has to receive or transmit bytes. The interrupt routine makes use of register bank 1. The transmission part of the routine starts at line 42. In lines 42-43, a check is made whether IIC\_CNT = NR\_BYTES. If true, all bytes are sent and a STOP condition may be generated (lines 44-45). Next the pointer for the internal RAM is restored (line 46) and the byte to be transmitted is fetched from the internal RAM (line 47). Then this byte is sent to the PCD8584 and the variables are updated (lines 47-49). The interrupt routine is left and the user program may proceed. The receive part starts from line 55. First a check is made if the next byte to be received is the last byte (lines 56-59). If true the ACK must be disabled when the last byte is received. This is accomplished by resetting the ACK bit in the control register S1 (lines 60-61). Next the received byte may be read (line 62) from data register S0. The byte will be temporary stored in R4 (line 63). Then a check is made if this interrupt was the first after a START condition. If so, the byte read has no meaning and the interrupt routine will be left (lines 68-70). However by reading the data register S0 the next read cycle is started. If valid data is received, it will be stored in the internal RAM addressed by the value of BASE (lines 71-73). Finally a check is made if all bytes are received. If true, a STOP condition will be sent (lines 75-78). #### **EXAMPLES** In the listing section (starting on page 8), some examples are shown that make use of the routines described before. The examples are transmission of a sequence, reception of 1<sup>2</sup>C data and an example that combines both. The first example sends bytes to the PCD8577 LCD driver on the OM1016 demonstration board. Lines 7 to 10 define the interface with the other modules and should be included in every user program. Lines 14 to 16 define the segments in the user module. It is completely up to the user how to organize this. Lines 24 and 28 are the reset and interrupt vectors. The actual user program starts at line 33. Here three variables are defined that are used in the I<sup>2</sup>C driver routines. Note that PCD8584 must be an even address, otherwise the wrong internal registers will be accessed! Lines 37-42 initialize the interrupt logic of the microcontroller. Next the PCD8584 will be initialized (line 45). The PCD8584 is now ready to transmit data. A table is made in the routine at line 61. For the PCD8577, the data is a control byte and the segment data. Note that the table does not contain the slave address of the LCD driver. In lines 51-54, variables are made ready to start the transmission. This consists of defining the direction of the transmission (DIR), the address where the data table starts (BASE), the number of bytes to transmit (NR\_BYTES, without slave address!) and the slave address (SLAVE) of the I<sup>2</sup>C peripheral that has to be accessed. In line 55 the transmission is started. Once the I<sup>2</sup>C transmission is started, the user program can do other tasks because the transmission works on interrupts. In this example a loop is performed (line 58). The user can check the end of the transmission during the other tasks, by testing the I2C. END bit regularly. The second example program receives 2 bytes from the PCF8574P I/O expander on the OM1016 demonstration board. Until line 45 the program is identical to the transmit routine because it consists of initialization and variable definition. From line 48, the variables are set for I<sup>2</sup>C reception. The received bytes are stored in RAM area from label TABLE. During reception, the user program can do other tasks. By testing the I2C\_END bit the user can determine when to start processing the data in the TABLE. The third example program displays time from the PCF8583P clock/calendar/RAM on the LCD display driven by the PCF8577. The LED display (driven by SAA1064) shows the value of the analog inputs of the A/D converter PCF8591. The four analog inputs are scanned consecutively. In this example, both transmit and receive sequences are implemented as shown in the previous examples. The main clock part is from lines 62-128. This contains the calls to the I<sup>2</sup>C routines. From lines 135-160, routines are shown that prepare the data to be transmitted. Lines 171 to 232 are the main program for the AD converter and LED display. Lines 239 to 340 contain routines used by the main program. This demo program can also be used with the I<sup>2</sup>C peripherals on the OM1016 demonstration board. April 1990 88 ``` ASM51 TSW ASSEMBLER Routines for PCD8584 LOC OB.T LINE SOURCE 1 $TITLE (Routines for PCD8584) $PAGELENGTH(40) ;Program written for PCD8584 as master 5 PUBLIC READBYTE, READCONTR, SENDBYTE PUBLIC SENDCONTR, START, STOP 6 PUBLIC I2C_INIT 7 EXTRN BIT(I2C_END, DIR) EXTRN DATA(SLAVE, IIC_CNT, NR_BYTES) EXTRN NUMBER (SLAVE_ADR, 12C_CLOCK, PCD8584) 10 ; ;Define code segment 11 12 ROUTINE SEGMENT CODE RSEG ROUTINE 13 14 ;SENDBYTE sends a byte to PCD8584 with A0=0 ;Byte to be send must be in accu 16 0000: 17 SENDBYTE: R 0000: 900000 18 MOV DPTR, #PCD8584 ; Register address 0003: F0 MOVX @DPTR.A ;Send byte 19 SEND: 0004: 22 20 21 22 ;SENDCONTR sends a byte to PCD8584 with A0=1 23 ;Byte to be send must be in accu 0005: 24 SENDCONTR: 0005: 900001 MOV DPTR, #PCD8584+01H ; Register address 25 0008: 80F9 26 JMP SEND 27 ;READBYTE reads a byte from PCD8584 with A0=0 28 ;Received byte is stored in accu 29 000A: 30 READBYTE: 000A: 900000 MOV DPTR, #PCD8584 ; Register address 31 000D: E0 32 REC: MOVX A, @DPTR ;Receive byte 000E: 22 33 34 ;READCONTR reads a byte from PCD8584 with A0=1 35 36 ;Received byte is stored in accu 37 000F: READCONTR: 000F: 900001 MOV DPTR, #PCD8584+01H ; Register address 38 0012: 80F9 39 JMP REC 40 ; 41 ;START tests if the I2C bus is ready. If ready a ;START-condition will be sent, interrupt generation ; and acknowledge will be enabled. 43 0014: 750000 44 START: MOV IIC_CNT, #00 ; Clear I2C byte counter 0017: 200002 45 JB DIR, PROCEED ; If DIR is 'receive' then 001A: 0500 46 INC NR_BYTES ; increment NR_BYTES 001C: 7440 47 PROCEED: MOV A, #40H ; Read STATUS register of ; 8584 001E: 120005 48 CALL SENDCONTR R 0021: 12000F R 49 TESTBB: CALL READCONTR 0024: 30E0FA 50 JNB ACC.0, TESTBB; Test BB/ bit 0027: E500 R 51 MOV A, SLAVE 0029: C200 52 CLR I2C END R ;Reset I2C ready bit 002B: 120000 R 53 CALL SENDBYTE ;Send slave address 002E: 744D 54 MOV A, #01001101B; Generate START, set ENI, ;set ACK 0030: 120005 55 CALL SENDCONTR 0033: 22 56 RET 57 ;STOP will generate a STOP condition and set the ; I2C_END bit 0034: 74C3 59 STOP: MOV A, #11000011B ``` 89 AN425 | 0036: 120 | 0005 R | 60 | CALL SENDCONTR ; Send STOP condition | |-----------|--------|----|--------------------------------------------------| | 0039: D20 | 00 R | 61 | SETB I2C_END ; Set I2C_END bit | | 003B: 22 | | 62 | RET | | | | 63 | <b>;</b> | | | | 64 | ;I2C_init does the initialization of the PCD8584 | | 003C: | | 65 | I2C_INIT: | | | | 66 | ;Write own slave address | | 003C: E4 | | 67 | CLR A | | 003D: 120 | 0005 R | 68 | CALL SENDCONTR ; Write to control register | | 0040: 740 | 00 R | 69 | MOV A, #SLAVE_ADR | | 0042: 120 | 0000 R | 70 | CALL SENDBYTE ; Write to own slave | | | | 4 | ;register | | | | 71 | ;Write clock register | | 0045: 742 | 20 | 72 | MOV A,#20H | | 0047: 120 | 0005 R | 73 | CALL SENDCONTR ; Write to control register | | 004A: 740 | 00 R | 74 | MOV A, #I2C_CLOCK | | 004C: 120 | 0000 R | 75 | CALL SENDBYTE ; Write to clock register | | 004F: 22 | | 76 | RET | | | | 77 | ; | | 0050: | | 78 | END | | | | | | April 1990 90 ``` ASM51 TSW ASSEMBLER I2C INTERRUPT ROUTINE LOC OBJ LINE SOURCE $TITLE (I2C INTERRUPT ROUTINE) $PAGELENGTH(40) 3 4 PUBLIC INTO SRV PUBLIC DIR, I2C_END 6 PUBLIC BASE, NR_BYTES, IIC_CNT, SLAVE EXTRN CODE (SENDBYTE, SENDCONTR, STOP) EXTRN CODE (READBYTE, READCONTR) ;Define variables in RAM 10 IIC_VAR SEGMENT DATA 11 RSEG IIC_VAR 0000: 12 BASE: DS 1 :Pointer to I2C table (till :256) 0001: 13 NR_BYTES: DS 1 ; Number of bytes to rcv/trm 0002: 14 IIC_CNT:DS 1 ; I2C byte counter 0003: 15 SLAVE: DS 1 ;Slave address after START 16 ; 17 ;Define variable segment 18 BIT_VAR SEGMENT DATA BITADDRESSABLE 19 RSEG BIT_VAR 0000: 20 STATUS: DS 1 R ;Byte with flags 21 I2C_END BIT STATUS.0 0000 R ;Defines if a I2C ;transmission is finished 22 ;'1' is finished ;'0' is not ready 23 0000 24 DIR ;Defines direction of I2C BIT STATUS.3 ;transmission 25 ;'1':Transmit '0':Receive 26 ;Define code segment for routine 28 IIC_INT SEGMENT CODE PAGE 29 RSEG IIC_INT 30 ; 31 ; Program uses registers in RB1 32 USING 1 33 0000: 34 INTO_SRV: 0000: C0E0 35 PUSH ACC ;Save acc. en psw on stack 0002: CODO 36 PUSH PSW 0004: 75D008 MOV PSW, #08H 37 ;Select register bank 1 0007: 300016 38 JNB DIR, RECEIVE ; Test direction bit 39 ;8584 is MST/TRM 40 41 ; Program part to transmit bytes to IIC bus 000A: E502 42 MOV A, IIC_CNT ; Compare IIC_CNT and ; NR_BYTES 000C: B50105 R 43 CJNE A, NR_BYTES, PROCEED 000F: 120000 44 CALL STOP ;All bytes transmitted 0012: 8032 45 JMP EXIT 0014: A800 46 PROCEED: MOV RO, BASE ; RAM pointer 0016: E6 47 MOV A,@RO ;Source is internal RAM 0017: 0500 R 48 INC BASE ;Update pointer of table 0019: 120000 R 49 CALL SENDBYTE ; Send byte to IIC bus 001C: 0502 50 INC IIC_CNT ;Update byte counter 001E: 8026 51 JMP EXIT 52 53 54 ; Program to receive byte from IIC bus 0020: 55 RECEIVE: 0020: E502 56 MOV A, IIC_CNT ;Test if last byte is to be ;received 57 0022: 04 TNC A ``` AN425 | 0023 | : 04 | | 58 | | INC A | | |------|-----------|---|----|----------|-------------------|------------------------------| | 0024 | : B50105 | R | 59 | | CJNE A, NR_BYTES | S, PROC_RD | | 0027 | : 7448 | | 60 | | MOV A, #01001000 | B;Last byte to be received. | | | | | | | | ;Disable ACK | | 0029 | : 120000 | R | 61 | | CALL SENDCONTR | ;Write control word to | | | | | | | | ; PCD8584 | | 0020 | : 120000 | R | 62 | PROC_RI | CALL READBYTE | ;Read I2C byte | | 002F | F: FC | | 63 | _ | MOV R4,A | ;Save accu | | | | | 64 | ; If REC | CEIVE is entered | after the transmission of | | | | | 65 | ; START- | address then the | e result of READBYTE is not | | | | | 66 | releva | ant. READBYTE is | used to start the generation | | | | | | of the | e clock pulses fo | or the next byte to read. | | | | | 67 | This s | situation occurs | when IIC_CNT is 0 | | 0030 | ): E4 | | 68 | • | CLR A | ;Test IIC_CNT | | 0031 | L: B50202 | R | 69 | | CJNE A, IIC_CNT, | , SAVE | | 0034 | : 8006 | | 70 | | JMP END_TEST | ;START is send. No relevant | | | | | | | | ;data in data reg. of 8584 | | 0036 | 5: A800 | R | 71 | SAVE: | MOV RO, BASE | | | 0038 | B: EC | | 72 | | MOV A,R4 | ;Destination is internal RAM | | 0039 | 9: F6 | | 73 | | MOV @RO, A | | | 0037 | A: 0500 | R | 74 | | INC BASE | | | 0030 | 2: 0502 | R | 75 | END_TES | ST:INC IIC_CNT | ;Test if all bytes are | | | | | | | | ;received | | 0031 | E: E501 | R | 76 | | MOV A, NR_BYTES | | | 0040 | ): B50203 | R | 77 | | CJNE A, IIC_CNT | ,EXIT | | 0043 | 3: 120000 | R | 78 | | CALL STOP | ;All bytes received | | | | | 79 | ; | | | | 0046 | 5: D0D0 | | 80 | EXIT: | POP PSW | ;Restore PSW and accu | | 0048 | B: D0E0 | | 81 | | POP ACC | | | 0042 | A: 32 | | 82 | | RETI | | | | | | 83 | ; | | | | 0041 | В: | | 84 | | END | | | | | | | | | | April 1990 92 ``` ASM51 TSW ASSEMBLER Send a string of bytes to the PCF8577 on OM1016 LINE SOURCE LOC OBJ 1 $TITLE (Send a string of bytes to the PCF8577 on OM1016) SPAGELENGTH (40) 2 3 ; ;This program is an example to transmit bytes via ; PCD8584 ;to the I2C-bus 7 PUBLIC SLAVE_ADR, I2C_CLOCK, PCD8584 EXTRN CODE(I2C_INIT,INTO_SRV,START) 8 9 BIT (I2C_END, DIR) EXTRN EXTRN DATA(BASE, NR_BYTES, IIC_CNT, SLAVE) 10 11 ; 12 ; 13 ; Define used segments 14 USER SEGMENT CODE ;Segment for user program 15 RAMTAB SEGMENT DATA ;Segment for table in ;internal RAM 16 RAMVAR SEGMENT DATA ;Segment for RAM variables ;in RAM 17 ; 18 19 RSEG RAMVAR 0000: 20 STACK: DS 20 ;Reserve stack area 21 22 ; CSEG AT 00H 23 0000: 020000 24 JMP MAIN :Reset vector 25 ; 26 CSEG AT 03H 2.7 0003: 020000 28 JMP INTO_SRV ;I2C interrupt vector ; (INTO/) 29 30 31 RSEG USER 32 ; Define I2C clock, own slave address and PCD8584 ; hardware address 0055 33 SLAVE_ADR EQU 55H ;Own slave address is 55H 001C 34 I2C_CLOCK EQU 00011100B ;12.00MHz/90kHz 0000 35 PCD8584 EQU 0000H ;PCD8584 address with A0=0 ;0000: 7581FF R 37 MAIN: MOV SP, #STACK-1 ; Initialize stack pointer 36 38 ;Initialize 8031 interrupt registers for I2C ;interrupt 0003: D2A8 39 SETB EX0 ;Enable interrupt INTO/ 0005: D2AF 40 SETB EA ;Set global enable 0007: D2B8 41 SETB PX0 ;Priority level '1' 0009: D288 42 SETB ITO ;INTO/ on falling edge 43 ; 44 ; Initialize PCD8584 000B: 120000 R 45 CALL I2C_INIT 46 ; Make a table in RAM with data to be transmitted. 47 000E: 120021 48 CALL MAKE_TAB 49 ;Set variables to control PCD8584 0011: D200 R 51 SETB DIR ;DIR='transmission' 0013: 750000 MOV BASE, #TABLE ; Start address of I2C-data R 52 MOV NR_BYTES, #05H ;5 bytes must be 0016: 750005 53 ;transferred 0019: 750074 54 MOV SLAVE, #01110100B ; Slave address PCF8577 ; + WR/ 001C: 120000 R 55 CALL START ;Start I2C transmission ``` AN425 | | | | 56 | ; | | | | |-------|------|---|----|---------|------|------------|----------------------------| | | | | 57 | ; | | | | | 001F: | 80FE | | 58 | LOOP: | JMP | LOOP | ;Endless loop when program | | | | | | | | | ;is finished | | | | | 59 | ; | | | | | | | | 60 | ; | | | | | 0021: | | | 61 | MAKE_TA | В: | | | | 0021: | 7800 | R | 62 | | MOV | R0, #TABLE | ;Make data ready for I2C | | | | | | | | | ;transmission | | 0023: | 7600 | | 63 | | MOV | @R0,#00 | ;Controlword PCF8577 | | 0025: | 80 | | 64 | | INC | R0 | | | 0026: | 76FC | | 65 | | MOV | @R0,#0FCH | ;'0' | | 0028: | 80 | | 66 | | INC | R0 | | | 0029: | 7660 | | 67 | | MOV | @R0,#60H | ;'1' | | 002B: | 80 | | 68 | | INC | R0 | | | 002C: | 76DA | | 69 | | MOV | @R0,#0DAH | ;'2' | | 002E: | 80 | | 70 | | INC | R0 | | | 002F: | 76F2 | | 71 | | MOV | @R0,#0F2H | ;'3' | | 0031: | 22 | | 72 | | RET | | | | | | | 73 | ; | | | | | | | | 74 | ; | | | | | | | | 75 | | RSE | G RAMTAB | | | 0000: | | R | 76 | TABLE: | DS : | 10 | ;Reserve space in internal | | | | | | | | | ;data RAM | | | | | 77 | | | | ;for I2C data to transmit | | | | | 78 | ; | | | | | | | | 79 | ; | | | | | 000A: | | | 80 | | END | | | April 1990 94 ``` ASM51 TSW ASSEMBLER Receive 2 bytes from the PCF8574P on OM1016 LOC OBJ LINE SOURCE 1 $TITLE (Receive 2 bytes from the PCF8574P on OM1016) SPAGELENGTH (40) 3 ;This program is an example to receive bytes via :PCD8584 ;from the I2C-bus 6 7 PUBLIC SLAVE_ADR, I2C_CLOCK, PCD8584 8 EXTRN CODE(I2C_INIT, INTO_SRV, START) EXTRN BIT(I2C_END,DIR) 10 EXTRN DATA (BASE, NR_BYTES, IIC_CNT, SLAVE) 11 ; 12 ; 13 ;Define used segments 14 USER SEGMENT CODE ;Segment for user program 15 RAMTAB SEGMENT DATA ;Segment for table in ; internal RAM 16 RAMVAR SEGMENT DATA ;Segment for RAM variables ;in RAM 17 : 18 19 RSEG RAMVAR 0000: 20 STACK: DS 20 ;Reserve stack area 21 ; 22 ; 23 CSEG AT 00H 0000: 020000 24 JMP MAIN ;Reset vector 25 ; 26 ; 27 CSEG AT 03H 0003: 020000 2.8 JMP INTO_SRV ;I2C interrupt vector ; (INTO/) 29 3.0 RSEG USER 32 ; Define I2C clock, own slave address and PCD8584 ;hardware address 0055 SLAVE_ADR EQU 55H 33 ;Own slave address is 55H 0010 34 I2C_CLOCK EQU 00011100B ;12.00MHz/90kHz 0000 35 PCD8584 EQU 0000H ; PCD8584 address with A0=0 36 ;0000: 7581FF R 37 MAIN: MOV SP, #STACK-1 ; Initialize stack pointer 38 ;Initialize 8031 interrupt registers for I2C ;interrupt 0003: D2A8 39 SETB EX0 ;Enable interrupt INTO/ 0005: D2AF 40 SETB EA ;Set global enable 0007: D2B8 SETB PX0 ;Priority level '1' 41 0009: D288 42 SETB ITO ;INTO/ on falling edge 43; 44 ; Initialize PCD8584 000B: 120000 R 45 CALL I2C_INIT 46 ;Set variables to control PCD8584 47 000E: C200 CLR DIR ;DIR='receive' 48 0010: 750000 49 MOV BASE, #TABLE ; Start address of I2C-data 0013: 750002 R 50 MOV NR_BYTES, #02H ;2 bytes must be received 0016: 75004F 51 MOV SLAVE, #01001111B ; Slave address PCF8574 ; + RD 0019: 120000 52 CALL START ;Start I2C transmission 53 ; 54; 001C+ 80FE 55 LOOP: JMP LOOP ; Endless loop when program ;is finished 56 ; ``` AN425 | | | 57 ; | | | |-------|---|----------|-------------|--------------------------------------| | | | 58 | RSEG RAMTAB | | | 0000: | R | 59 TABLE | DS 10 | ;Reserve space in internal ;data RAM | | | | 60 | | ;for received I2C data | | | | 61 ; | | | | | | 62 ; | | | | 000A: | | 63 | END | | April 1990 96 ``` ASM51 TSW ASSEMBLER Demo program for PCD8584 I2C-routines LOC OBJ LINE SOURCE 1 $TITLE (Demo program for PCD8584 I2C-routines) $PAGELENGTH(40) ; Program displays on the LCD display the time (with ; PCF8583). Dots on LCD display blink every second. ;On the LED display the values of the successive ; analog input channels are shown. ; Program reads analog channels of PCF8591P. ; Channel number and channel value are displayed ; successively. ; Values are displayed on LCD and LED display on I2C ; demo board. 10 11 PUBLIC SLAVE_ADR, I2C_CLOCK, PCD8584 12 EXTRN CODE (I2C_INIT, INTO_SRV, START) 13 EXTRN BIT (I2C_END, DIR) 14 EXTRN DATA (BASE, NR_BYTES, IIC_CNT, SLAVE) 16 17 ;Define used segments SEGMENT CODE ; Segment for user program 19 RAMTAB SEGMENT DATA ;Segment for table in ;internal RAM 20 RAMVAR SEGMENT DATA ;Segment for variables 21 22 RSEG RAMVAR 0000: 23 STACK: DS 20 ;Stack area (20 bytes) 0014: 24 PREVIOUS: DS 1 ;Store for previous seconds 0015: CHANNEL:DS 1 25 ;Channel number to be ;sampled 0016: 26 AN_VAL: DS 1 ;Analog value sampled ;channel 0017: 27 CONVAL: DS 3 ;Converted BCD value sampled ; channel 2.8 29 CSEG AT 00H 0000: 020000 R 30 LJMP MAIN ;Reset vector 31 ; 32 CSEG AT 03H : TNTO / 0003: 020000 R 33 LJMP INTO_SRV ; Vector I2C-interrupt 34 35 36 RSEG USER37 ;Define I2C clock, own slave address and address for ;main processor 0055 38 SLAVE_ADR EOU 55H ;Own slaveaddress is 55h 001C 39 I2C_CLOCK EQU 00011100B ;12.00MHz/90kHz 0000 PCD8584 EQU 0000H 40 ; Address of PCD8584. This ; must be an EVEN number!! 41 ;Define addresses of I2C peripherals 00A3 PCF8583R EQU 10100011B ;Address PCF8583 with Read ;active 00A2 PCF8583W EQU 10100010B ; Address PCF8583 with Write 43 ;active 009F PCF8591R EQU 10011111B ;Address PCF8591 with Read :active 009E PCF8591W EQU 10011110B ;Address PCF8591 with Write ;active 0074 PCF8577W EQU 01110100B ; Address PCF8577 with Write ;active 0076 SAA1064W : EQU 01110110B ; Address SAA1064 with Write ;active 48 0000: 7581FF 49 MAIN: MOV SP, #STACK-1 ; Define stack pointer ``` ``` ASM51 TSW ASSEMBLER Demo program for PCD8584 I2C-routines LINE SOURCE LOC OBJ 50 ;Initialize 80C31 interrupt registers for I2C ;interrupt (INTO/) ;Enable interrupt INTO/ SETB EX0 51 0003: D2A8 ;Set global enable SETB EA 0005: D2AF 52 ;Priority level is '1' SETB PX0 0007: D2B8 53 ;INTO/ on falling edge SETB ITO 0009: D288 54 55 ; Initialize PCD8584 CALL I2C_INIT 56 000B: 120000 R 57 ; MOV CHANNEL, #00 ; Set AD-channel 000E: 751500 R 58 59 60 ; Time must be read from PCD8583. 61 ; First write word address and control register of ; PCD8583. SETB DIR ;DIR='transmission' 62 0011: D200 R MOV BASE, #TABLE ; Start address I2C data 0013: 750000 63 R MOV NR_BYTES, #02H ; Send 2 bytes 0016: 750002 R 64 MOV SLAVE, #PCF8583W 0019: 7500A2 R 65 CLR A 001C: E4 66 MOV TABLE, A ;Data to be sent (word 001D: F500 67 ;address). ; ' ' ' " (control R 68 MOV TABLE+1, A 001F: F501 ;byte) 0021: 120000 R 69 CALL START ;Start transmission. 70 FIN_1: JNB I2C_END, FIN_1 ; Wait till transmission 0024: 3000FD R ;finished 71 ; Send word address before reading time REPEAT: SETB DIR ;'transmission 0027: D200 R 72 MOV BASE, #TABLE ; I2C data 0029: 750000 73 R MOV SLAVE, #PCF8583W 002C: 7500A2 R 74 002F: 7401 75 MOV A, #01 MOV NR_BYTES, A ; Send 1 byte 76 0031: F500 ;Data to be sent is '1' MOV TABLE, A 77 0033: F500 R ;Start I2C transmission 0035: 120000 R 0038: 3000FD R 78 CALL START 79 FIN_2: JNB I2C_END, FIN_2 ; Wait till transmission ;finished 80 ; 81 ; Time can now be read from PCD8583. Data read is 82 ; hundredths of sec's, sec's, min's and hr's ;DIR='receive' 003B: C200 CLR DIR R 83 MOV BASE, #TABLE ; I2C table 003D: 750000 R 84 0040: 750004 R MOV NR_BYTES, #04; 4 bytes to receive 85 MOV SLAVE, #PCF8583R 0043: 7500A3 R CALL START ;Start I2C reception 0046: 120000 R 87 88 FIN_3: JNB I2C_END, FIN_3 ; Wait till finished 0049: 3000FD R 89 ; 90 ;Transfer data to R2...R5 MOV RO, #TABLE ; Set pointers 004C: 7800 91 ;Pointer R2 004E: 7902 92 MOV R1,#02H 93 TRANSFER: MOV A, @RO 0050: E6 94 MOV @R1,A 0051: F7 INC RO 95 0052: 08 INC R1 96 0053: 09 DJNZ NR_BYTES, TRANSFER 97 0054: D500F9 R ;Mask of hour counter 98 MOV A,R5 0057: ED 99 ANL A, #3FH 0058: 543F MOV R5, A 005A: FD 100 101 ; 102 ; Data must now be displayed on LCD display. 103 ; First minutes and hours (in R4 and R5) must be 104 ; converted from BCD to LCD segment data. The segment 105 ; will be transferred to TABLE. RO is pointer to table ``` ``` ASM51 TSW ASSEMBLER Demo program for PCD8584 I2C-routines LOC OBJ LINE SOURCE 005B: 7800 R 106 MOV RO, #TABLE 005D: 7600 107 MOV @RO,#00H ;Control word for PCF8577 005F: 08 108 INC R0 0060: 120080 R 109 CALL CONV 110 ; 111 ; Switch on dp between hours and minutes 0063: 430301 R 112 ORL TABLE+3,#01H 113 ; If 1sb of seconds is '0' then switch on dp. 0066: EB 114 MOV A,R3 Get seconds 0067: 13 115 RRC A ;lsb in carry 0068: 4003 116 JC PROCEED 006A: 430101 R 117 ORL TABLE+1, #01H; switch on dp 118 ; 119 ; Now the time (hours, minutes) can be displayed on ;the LCD 006D: 120 PROCEED: 006D: D200 R 121 ;Direction 'transmit' SETB DIR 006F: 750000 R 122 MOV BASE, #TABLE 0072: 750005 R 123 MOV NR_BYTES, #05H 0075: 750074 R 125 124 MOV SLAVE, #PCF8577W 0078: 120000 R CALL START ;Start transmission 126 ; 007B: 3000FD R 127 FIN_4: JNB I2C_END, FIN_4 007E: 8026 128 JMP ADCON ; Proceed with AD-conversion ;part 129 ; 130 ;****************************** 131 ; Routines used by clock part of demo 133 ; CONV converts hour and minute data to LCD data and ;stores 134 ; it in TABLE. 0080: 90009C R 135 CONV: MOV DPTR, #LCD_TAB ; Base for LCD segment ;table 0083: ED MOV A,R5 136 ;Hours to accu 0084: C4 137 SWAP A ;Swap nibbles 0085: 120096 R 138 CALL LCD_DATA ;Convert 10's hours to LCD ;data in table 0088: ED MOV A,R5 139 ;Get hours 0089: 120096 R 140 CALL LCD_DATA 008C: EC 141 MOV A,R4 ;Get minutes 008D: C4 142 SWAP A 008E: 120096 R 143 CALL LCD_DATA ;Convert 10's minutes 0091: EC 144 MOV A,R4 0092: 120096 R 145 CALL LCD_DATA ; Convert minutes 0095: 22 146 RET 147 ; 148 ;LCD_DATA gets data from segment table and stores it ;in TABLE 0096: 540F 149 LCD_DATA: ANL A, #0FH ;Mask off LS-nibble 0098: 93 MOVC A, @A+DPTR ; Get LCD segment data 150 0099: F6 MOV @RO,A 151 ;Save data in table 009A: 08 152 INC RO 009B: 22 153 154 ; 155 ;LCD_TAB is conversion table for LCD 009C: 156 LCD_TAB: 009C: FC60DA 157 DB OFCH, 60H, 0DAH; '0', '1', '2' 009F: F266B6 158 DB 0F2H,66H,0B6H; '3','4','5' 00A2: 3EE0FE 159 DB 3EH, 0E0H, 0FEH; '6', '7', '8' 00A5: E6 160 DB 0E6H ; '9' 161 ; ``` Demo program for PCD8584 I2C-routines ``` ASM51 TSW ASSEMBLER LINE SOURCE LOC OBJ 163 ; 164 165 ; These part of the program reads an analog ; input-channel. 166 ; Displaying is done on the LED-display 167 ;On odd-seconds the channel number will be ; displayed. 168 ;On even-seconds the analog value of this channel is ;displayed 169 ; Then the next channel is displayed. 170 ; 171 ADCON: MOV A,R3 ;Get seconds 00A6: EB ;lsb to carry RRC A 172 00A7: 13 ;Even seconds; do a JNC NEW_MEAS 00A8: 503C 173 ; measurement on the current ;channel 174 ; 175 ;Display and/or update channel ;Restore accu 176 RLC A 00AA: 33 CJNE A, PREVIOUS, NEW_CH ; If new seconds, 00AB: B51402 177 ;update channel number 178 JMP DISP_CH 00AE: 800A R 179 NEW_CH: INC CHANNEL 00B0: 0515 ;If channel=4 then MOV A, CHANNEL R 180 00B2: E515 ;channel:=0 CJNE A, #04, DISP_CH 181 00B4: B40403 MOV CHANNEL, #00 182 00B7: 751500 R 183 DISP_CH:MOV PREVIOUS,R3 ;Update previous seconds 00BA: 8B14 R MOV A, CHANNEL ;Get segment value of 00BC: E515 R 184 ; channel MOV DPTR, #LED_TAB 00BE: 900193 185 MOVC A, @A+DPTR 186 00C1: 93 187 ; ;Fill table with I2C data MOV RO, #TABLE 00C2: 7800 R 188 ;SAA1064 instruction byte MOV @R0,#00 189 00C4: 7600 190 INC RO 00C6: 08 ;SAA1064 control byte MOV @R0,#77H 00C7: 7677 191 INC RO 192 00C9: 08 ;Channel number MOV @RO, A 193 00CA: F6 CLR A 00CB: E4 194 INC RO 195 00CC: 08 ;Second digit MOV @RO,A 196 00CD: F6 INC RO 197 00CE: 08 MOV @RO, A ;Third digit 00CF: F6 198 INC RO 00D0: 08 199 MOV @RO,A ;Fourth byte 00D1: F6 200 201 ; ;I2C transmission of channel 00D2: D200 R 202 SETB DIR ;number MOV BASE, #TABLE 203 00D4: 750000 R MOV NR_BYTES, #06H 204 00D7: 750006 MOV SLAVE, #SAA1064W 205 00DA: 750076 CALL START 206 00DD: 120000 R 207 JNB I2C_END, FIN_5 00E0: 3000FD 208 FIN_5: ; Repeat clock and AD cycle JMP REPEAT 00E3: 020027 209 ; again 210 211 ; ``` ``` ASM51 TSW ASSEMBLER Demo program for PCD8584 I2C-routines LOC OBJ LINE SOURCE 212 ; Measure and display the value of an AD-channel 00E6: 120108 213 NEW_MEAS: CALL AD_VAL ;Do measurement 214 ; Wait till values are available 00E9: 3000FD R 215 FIN_6: JNB I2C_END, FIN_6 216 ;Relevant byte in TABLE+1. Transfer to AN_VAL 00EC: 7801 R 217 MOV RO, #TABLE+1 00EE: 8616 R 218 MOV AN_VAL,@R0 00F0: E516 R 219 MOV A, AN_VAL ;Channel value in accu for ;conversion 220 ;AN_VAL is converted to BCD value of the measured ;voltage. 221 ;Input value for CONVERT in accu 222 ; Address for MSByte in R1 00F2: 7917 R 223 MOV R1, #CONVAL 00F4: 120154 R 224 CALL CONVERT 225 ;Convert 3 bytes of CONVAL to LED-segments 00F7: 900193 R MOV DPTR, #LED_TAB ; Base of segment table 226 00FA: 7817 R 227 MOV R0, #CONVAL 00FC: 12018A R 228 CALL SEG_LOOP 229 ;Display value of channel to LED display 00FF: 12012C R 230 CALL LED_DISP 0102: 3000FD R 231 FIN_8: JNB I2C_END,FIN_8 ;Wait till I2C ;transmission is ended 0105: 020027 JMP REPEAT R 232 ;Repeat clock and AD cycle 233 ; 235 ; Routines used for AD converter. 237 ;AIN reads an analog values from channel denoted by ; CHANNEL. 238 ;Send controlbyte: 0108: D200 R 239 AD_VAL: SETB DIR ;I2C transmission 010A: 7800 240 MOV RO, #TABLE ; Define control word R 010C: A615 R 241 MOV @R0, CHANNEL 010E: 750000 R 242 MOV BASE, #TABLE ; Set base at table 0111: 750001 R 243 MOV NR_BYTES, #01H ; Number of bytes to be :send 0114: 75009E MOV SLAVE, #PCF8591W ; Slave address PCF8591 R 244 0117: 120000 R 245 CALL START ;Start transmission of ;controlword 011A: 3000FD R 246 FIN_7: JNB I2C_END,FIN_7 ; Wait until transmission is ;finished 247 ; Read 2 data bytes from AD-converter ; First data byte is from previous conversion and not 248 249 ;relevant 011D: C200 250 CLR DIR ;I2C reception 011F: 750000 R 251 MOV BASE, #TABLE ; Bytes must be stored in :TABLE 0122: 750002 R 252 MOV NR_BYTES, #02H; Receive 3 bytes 0125: 75009F 253 R MOV SLAVE, #PCF8591R ;Slave address PCF8591 0128: 120000 R 254 CALL START 012B: 22 255 RET 256 ; 257 ;LED_DISP displays the data of 3 bytes from address ; CONVAL 012C: 258 LED_DISP: 012C: 431780 R 259 ORL CONVAL, #80H ; Set decimal point 012F: 7800 R 260 MOV RO, #TABLE 0131: 7917 MOV R1, #CONVAL R 261 0133: 7600 262 MOV @R0,#00 ;SAA1064 instruction byte 0135: 08 263 INC RO ``` | ASM51 | TSW | AS | SEMB | LER | Demo pro | gram for PCD8584 | I2C-routines | |-------|----------------|-----|------|------|-----------|--------------------------------------|------------------------------------------------| | LOC | OBJ | | | LINE | SOURCE | | | | 0136: | 7677 | | | 264 | | MOV @R0,#0111011 | 1B ;SAA1064 control byte | | 0138: | | | | 265 | | INC R0 | | | 0139: | | | | 266 | | MOV @RO,#00 | ;First LED digit | | 013B: | | | | 267 | | INC R0 | | | | 12018 | 5 | R | 268 | | CALL GETBY | ;Second digit | | | 12018 | | R | 269 | | CALL GETBY | ;Third digit | | | 12018 | | R | 270 | | CALL GETBY | ;Fourth digit | | 0145: | | | R | 271 | | SETB DIR | ;I2C transmission | | | 75000 | 0 | R | 272 | | MOV BASE, #TABLE | | | | 75000 | | R | 273 | | MOV NR_BYTES, #06 | | | | 75007 | | R | 274 | | MOV SLAVE, #01110 | 110B | | | 12000 | | R | 275 | | CALL START | ;Start I2C transmission | | 0153: | | | | 276 | | RET | | | 0100. | | | | 277 | ; | | | | | | | | 278 | ; CONVERT | calculates the | voltage of the analog value. | | | | | | 279 | ;Analog | value must be in | accu | | | | | | 280 | ;BCD res | sult (3 bytes) is | stored from address stored | | | | | | 281 | | ation: AN_VAL*(5/ | (256) | | 0154 | 75F00 | 15 | | 282 | | MOV B, #05 | | | 0157: | | | | 283 | | MUL AB | | | 0137. | | | | 284 | ;b2b0 | of reg. B: 2E+2 | 22E0 | | | | | | 285 | ;b7b0 | of accu : 2E-1 | 2E-8 | | 0158 | A7F0 | | | 286 | • | MOV @R1,B | ;Store MSB (10E0-units) | | 015A: | | | | 287 | | INC R1 | | | | 3: 7700 | ) | | 288 | | MOV @R1,#00 | ;Calculate 10E-1 unit | | 0151 | . ,,,,, | • | | | | | ;(10E-1 is 19h) | | 0150 | B41C | 12 | | 289 | TEN CH: | CJNE A, #19H+03H | V1 ; Check if accu <= 0.11 | | | 8002 | | | 290 | | JMP TENS | ;accu=0.11; update tens | | | 4006 | | | 291 | V1: | JC NX_CON | ;accu<0.11; update hundreds | | 0164 | | | | 292 | TENS: | CLR C | ;Calculate new value | | | 9419 | | | 293 | | SUBB A,#19H | | | 0167 | | | | 294 | | | ;Update BCD byte | | | : 80F3 | | | 295 | | JMP TEN_CH | | | 0100 | . 0013 | | | 296 | | tion may be nece<br>t 0.0976. | ssary. With 8 bits '0.1' is | | | | | | 297 | ;A digi | t of 'OA' may ap<br>enting the digit | pear. Correct this by | | | | | | 298 | ·The in | termediate resul | t result must be corrected | | | | | | 250 | | 0*(0.1-0.0976) | | | | | | | 299 | ;This i | | | | 0167 | : B70A | 0.3 | | 300 | NX CON: | CINE GR1, #OAH, P | ROC_CON ; If digit is 'OA' | | | | .03 | | 301 | m_com | DEC @R1 | ; then correct | | 016D | | | | 301 | | ADD A,#19H | | | | : 2419<br>: 09 | | | 303 | PROC CO | N:INC R1 | | | | : 7700 | | | 304 | TROC_CC | MOV @R1,#00 | ;Calculate 10E-2 units | | | : 7700 | | | 305 | HUND: | CJNE A, #03H, V2 | ;Check if accu <= 10E-2 | | | : 8002 | | | 306 | nond. | JMP HUNS | ;accu=10E-2; update hundreds | | | : 4006 | | | 307 | V2: | JC FINISH | 100 0 | | 0178 | .: C3 | | | 308 | HUNS: | CLR C | ;Calculate new value | | | : 9403 | R | | 309 | | SUBB A, #03H | | | | ): 07 | • | | 310 | | INC @R1 | ;Update BCD byte | | | . 80F3 | 3 | | 311 | | JMP HUND | | | | ): B70 | | | 312 | FINISH | : CJNE @R1,#0AH,E | FIN ; Check if result is 'OA'. ; Then correct. | | 0183 | 3: 17 | | | 313 | | DEC @R1 | | | | 1: 22 | | | 314 | | RET | | | 0104 | | | | 315 | | | | | | | | | 316 | ; CALLB | Y transfers byte | from @R1 to @R0 | | 018 | 5: E7 | | | 317 | | MOV A, @R1 | | | | 5: F6 | | | 318 | | MOV @RO,A | | | 0.20 | | | | | | | | AN425 | ASM51 | TSW | ASSEMB | LER | Demo program for PCD8584 I2C-routines | |-------|--------|--------|------|------------------------------------------------------| | LOC | OBJ | | LINE | SOURCE | | 0187: | 08 | | 319 | INC RO | | 0188: | 09 | | 320 | INC R1 | | 0189: | 22 | | 321 | RET | | | | | 322 | | | | | | 323 | ;SEG_LOOP converts 3 values to segment values. | | | | | 324 | ;RO contains address of source and destination | | | | | 325 | ;DPTR contains base of table | | 018A: | 7903 | | 326 | SEG_LOOP: MOV R1,#03 ;Loop counter | | 018C: | E6 | | 327 | INLOOP: MOV A, @RO ;Get value to be displayed | | 018D: | 93 | | 328 | MOVC A, @A+DPTR ;Get segment value from | | | | | | ; table | | 018E: | | | 329 | MOV @RO,A ;Store segment data | | 018F: | 08 | | 330 | INC RO | | 0190: | | | 331 | DJNZ R1, INLOOP | | 0192: | 22 | | 332 | RET | | | | | 333 | | | | | | 334 | | | | | | 335 | ;LED_TAB is conversion table for BCD to LED segments | | 0193: | | | 336 | LED_TAB: | | | 7D483E | | 337 | DB 7DH,48H,3EH ; '0','1','2' | | | 6E4B67 | | 338 | DB 6EH, 4BH, 67H ; '3', '4', '5' | | | 734C7F | | 339 | DB 73H,4CH,7FH ; '6','7','8' | | 019C: | 4F | | 340 | DB 4FH ; '9' | | | | | 341 | | | | | | | ********************** | | | | | 343 | | | | | | 344 | RSEG RAMTAB | | 0000: | | R | | TABLE: DS 10 | | | | | 346 | | | 000A: | | | 347 | END | April 1990 Philips Semiconductors Application note ### Using the 8XC751/752 in multimaster I<sup>2</sup>C applications **AN430** #### INTRODUCTION The Philips Semiconductors 83C751/87C751 offers the advantages of the 80C51 architecture in a small package and at a low cost. It combines the benefits of a high performance microcontroller with on-board hardware supporting the Inter Integrated Circuit (I<sup>2</sup>C) bus interface. The Inter IC (I<sup>2</sup>C) bus developed by Philips allows integrated circuits to communicate directly with each other via a simple bidirectional 2-wire bus. The comprehensive family of CMOS and bipolar ICs incorporating the on-chip I<sup>2</sup>C interface offers many advantages to designers of digital control for industrial, consumer and telecommunications equipment. Interfacing the devices in an I<sup>2</sup>C based system is very simple as they connect directly to the two bus lines: a serial data line (SDA) and a serial clock line (SCL). System design can rapidly progress from block diagram to final schematics, as there is no need to design bus interfaces. In addition, functional blocks on the block diagram correspond to actual ICs. A prototype system or a final product version can be easily modified or upgraded by 'clipping' or 'unclipping' ICs to or from the bus. The simplicity of designing with the I<sup>2</sup>C bus does not reduce its effectiveness: it is a reliable, multimaster bus with integrated addressing and data-transfer protocols. The I<sup>2</sup>C-bus compatible ICs give cost reduction benefits through smaller IC packages and a minimization of PCB traces and glue logic. The availability of microcontrollers, like the 83C751, with on-board I<sup>2</sup>C interface is a very powerful tool for system designers. The integrated protocols allow systems to be completely software defined. Software development time of different products can be reduced by assembling a library of re-usable software modules. In addition, the multimaster capability allows rapid testing and alignment of end-products via external connections to an assembly-line computer. The mask programmable 83C751 and its EPROM version, 87C751, can operate as a master or a slave device on the I<sup>2</sup>C small area network. In addition to the efficient interface to the dedicated function ICs in the I<sup>2</sup>C family the on-board interface facilitates I/O and RAM expansion, access to EEPROM, and processor-to-processor communications. The 83C752 and its EPROM version, 87C752, are essentially the 83C751/87C751 with the addition of a five channel multiplexed 8-bit A/D converter and an 8-bit PWM output. As the I<sup>2</sup>C bus interface is identical, the programming example and the discussion relates to both processors. The multimaster capability of the I<sup>2</sup>C bus allows easy integration and expansion of relatively complex systems, in which different devices can independently initiate data transfers. Integration of a multimaster system is easy as a Master on the bus does not have to coordinate its data transfer with other potential Master devices—arbitration and synchronization are taken care of by the hardware and bus protocols. Expanding a system with a new device is trivial—it is "clipped" onto the two serial bus lines, and the new device may act as a Master without any modification to the other devices (see Figure 1). Microcontrollers like the S8XC751/752 on the I<sup>2</sup>C bus are extremely powerful, as they can be programmed to be both Masters and Slaves in the same system. This way the microcontroller may initiate communication on the bus, and when requested, will respond to a data transfer request by another device. In this Application Note we shall discuss the most important technical features of the I<sup>2</sup>C bus and describe the special I<sup>2</sup>C hardware interface of the 8XC751/752. We shall demonstrate with an example how the microcontroller can be programmed for a multimaster environment. The communications routines of the example are quite general, and can be ported to many applications—so we shall discuss in detail the software interface to these routines. The description of the 8XC751 I<sup>2</sup>C interface hardware and part of the general discussion of the I<sup>2</sup>C bus is similar to Application Note AN422 which dealt with the microcontroller in a single-master environment. Most of the added discussions relate to the multimaster aspects of the bus. Additional information for the I<sup>2</sup>C bus and the 83C751/752 Microcontroller can be found in the Philips Semiconductors Microcontroller Data Handbook (IC20). Figure 1. Example of an I<sup>2</sup>C-bus Configuration Philips Semiconductors Application note #### Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 Figure 2. Connection of I<sup>2</sup>C-bus Devices to the I<sup>2</sup>C-bus #### THE I2C BUS The two lines of the I<sup>2</sup>C bus are a serial data line (SDA) and a serial clock line (SCL). A typical system configuration is shown in Figure 2. Each device is recognized by a unique address—whether it is a microcomputer, LCD driver, memory or keyboard interface—and can operate as either a transmitter or a receiver, depending on the function of the device. A device generating a message or data is a transmitter, and a device receiving the message or data is a receiver. Obviously, a passive function like an LCD driver could only be a receiver, while a microcontroller or a memory can both transmit and receive data. Every device connected to the bus must have an open-drain or an open-collector output for both the data (SDA) and the clock (SCL) lines. Each one of the lines is connected to the positive supply via a common pull-up resistor (see Figure 2). This implements a wired-AND function, and each of the bus lines which will have the HIGH level only if all the output transistors tied to it are switched off. Data on the I $^2$ C bus can be transferred at a rate up to 100kbit/s. The number of devices connected to the bus is limited only by the maximum bus capacitance of 400pF. As different technology devices can be connected to the I $^2$ C bus, the levels of the logical 0 (Low) and logical 1 (High) are not fixed and depend on the appropriate level of $V_{DD}$ . #### MASTERS AND SLAVES When a data transfer takes place on the bus, a device can be either a master or a slave. The device which initiates the transfer, and generates the clock signals for this transfer is the master. At that time any device addressed is considered a slave. It is important to note that a master could be either a transmitter or a receiver: a master microcontroller may send data to a RAM acting as a transmitter, and then interrogate the RAM for its contents acting as a receiver—in both cases being the master initiating the transfer. In the same manner, a slave could be both a receiver and a transmitter. The I<sup>2</sup>C is a multimaster bus. It is possible to have in one system more than one device capable of initiating transfers and controlling the bus. A microcontroller may act as a master for one transfer, and then be the slave for another transfer, initiated by another processor on the network. The master/slave relationships on the bus are not permanent, and exist per transfer. As more than one master may be connected to the bus it is possible that two devices will try to initiate transfer at the same time. Obviously, in order to eliminate bus collisions and communications chaos, an arbitration procedure is necessary. The I<sup>2</sup>C design has an inherent arbitration and clock synchronization procedure relying on the wired-AND connection of the devices on the bus. In a typical multimaster system, a microcontroller program should allow it to gracefully switch between master and slave modes and preserve data integrity upon loss of arbitration. #### **DATA TRANSFERS** One data bit is transferred during each clock pulse (Figure 3). The data on the SDA line must remain stable during the HIGH period of the clock pulse in order to be valid. Changes in the data line at this time will be interpreted as control signals. A HIGH-to-LOW transition of the data line (SDA) while the clock signal (SCL) is HIGH indicates a Start condition, and a LOW-to-HIGH transition of the SDA while SCL is HIGH defines a Stop condition (Figure 4). The bus is considered to be busy after the Start condition and free again a certain time after the Stop condition. The Start and Stop conditions are always generated by the master. The number of data bytes transferred between the Start and Stop condition from transmitter to receiver is not limited. Each byte, which must be eight bits long, is transferred serially with the most significant bit first, and is followed by an acknowledge bit (Figure 5). The clock pulse related to the acknowledge bit is generated by the master. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, while the transmitting device releases the SDA line (HIGH) during this pulse (Figure 6). A slave receiver must generate an acknowledge after the reception of each byte, and a master must generate one after the reception of each byte clocked out of the slave transmitter. If a receiving device cannot receive the data byte immediately, it can force the transmitter into a wait state by holding the clock line (SCL) LOW. When designing a system it is necessary to take into account cases when acknowledge is not received. This happens, for example, when the addressed device is busy in a real time operation. In such a case the master, after an appropriate "time-out", should abort the transfer by generating a Stop condition, allowing other transfers to take place. These "other transfers" could be initiated by other masters in a multimaster system or by this same master. An exception to the "acknowledge after every byte" rule occurs when a master is a receiver: it must signal an end of data to the transmitter by NOT signalling an acknowledge on the last byte that has been clocked out of the slave. The acknowledge related clock, generated by the master, should still take place but the SDA line will not be pulled down. In order to indicate that this is an active and intentional lack of acknowledgement, we shall term this special condition as a "Negative ACK". The bus design includes special provisions for interfacing to microprocessors which implement all the $I^2C$ communications in software only—it is called "Slow Mode". When all the devices on the network have built-in $I^2C$ hardware support the Slow Mode is irrelevant. Figure 3. Bit Transfer on the I<sup>2</sup>C Bus Figure 4. Start and Stop Conditions Figure 5. Data Transfer on the I<sup>2</sup>C Bus Figure 6. Acknowledge on the I<sup>2</sup>C Bus AN430 Figure 7. A Complete Data Transfer on the I<sup>2</sup>C-Bus Figure 8. I<sup>2</sup>C Data Formats ## ADDRESSING AND TRANSFER FORMATS Each device on the bus has its own unique address. Before any data is transmitted on the bus, the master transmits on the bus the address of the slave of this transaction. A well-behaved slave, if it exists on the network, should of course acknowledge the master's addressing. The addressing is done with the first byte transmitted by the master after the Start condition. An address on the network is seven bits long, appearing as the most significant bits of the address byte. The last bit is a direction (R/W) bit. A zero indicates that the master is transmitting (WRITE) and a one indicates that the master requests data (READ). A complete data transfer, comprised of an address byte indicating a WRITE and two data bytes is shown in Figure 7. When an address is sent, each device in the system compares the first seven bits after the Start with its own address. If there is a match, the device will consider itself addressed by the master and will send an acknowledge. The device could also determine if in this transaction it is assigned the role of a slave receiver or slave transmitter, depending on the R/W bit. Each node of the I<sup>2</sup>C network has a unique seven bit address. The address of a microcontroller is, of course, fully programmable, while peripheral devices usually have fixed and programmable address portions. In addition to the "standard" addressing discussed here, the I<sup>2</sup>C bus protocol allows for "general call" addressing and interfacing to CBUS devices. When the master is communicating with one device only, data transfers follow the format of Figure 8 where the R/W bit could indicate either direction. After completing the transfer and issuing a Stop condition, if a master would like to address some other device on the network, it could start another transaction by issuing a new Start. Another way for a master to communicate with several different devices would be by using a "repeated start". After the last byte of the transaction was transferred, including its acknowledge (or Negative ACK), the master issues again a Start, followed by address byte and data, without effecting a Stop. The master may communicate with a number of different devices, combining READS and WRITES. Only after the transfer with the last slave took place, the master issues a Stop and releases the bus. Possible data formats are demonstrated in Figure 8. Note that the repeated start allows for both change of a slave and a change of direction, without releasing the bus. We shall see later on that the change of direction feature can come in handy even when dealing with a single device. In a single master system the repeated start mechanism is more efficient than terminating each transfer with a Stop and starting again. In a multimaster environment the determination of which format is more efficient could be more complicated, as when a master is using repeated starts it occupies the bus for a long time and prevents other devices from initiating transfers. ### USE OF SUB-ADDRESSES For some ICs on the I<sup>2</sup>C bus the device address alone is not sufficient for effective communications and a mechanism for addressing the internals of the device is necessary. A typical example is addressing memories, when we want to access a specific word inside the device or a sequence of memory locations starting at a specific internal address. A typical I<sup>2</sup>C memory device like the PCF8570 RAM contains a built-in word address register that is incremented automatically after each read or written data byte. When a master communicates with the PCF8570 it must send a sub-address in the byte following the slave address byte. This sub-address is the internal address of the word the master wants to access for a single byte transfer or the beginning of a sequence of locations for a multi-byte transfer. A sub-address is an eight bit byte, unlike the device address it does not contain a direction (R/W) bit, and like any byte transferred on the bus it must be followed by an acknowledge. A memory write cycle is shown in Figure 9(a). The Start is followed by a slave byte with the direction bit set to WRITE, a sub-address byte, a number of data bytes and a Stop signal. The sub-address is loaded into the word address memory. The data bytes which follow will be written one after the other starting with the sub-address location and the register is incremented automatically. The memory read cycle (Figure 9(b)) commences in a similar manner with the master sending a slave address with the direction bit set to WRITE with a following sub-address. Then, in order to reverse the direction of the transfer, the master issues a repeated Start followed again by the memory device address, but this time with the direction bit set to READ. The data bytes starting at the internal sub-address will be clocked out of the device with each followed by a master-generated acknowledge. The last byte of the read cycle will be followed by a Negative ACK, signalling the end of transfer. The cycle is terminated by a Stop signal. Figure 9. I<sup>2</sup>C Sub-Address Usage AN430 Figure 10. Clock Synchronization During the Arbitration Procedure Figure 11. Arbitration Procedure of Two Masters ## **ARBITRATION IN A MULTIMASTER SYSTEM** The decision about which master has control over the I2C bus is based solely on the address and data sent by competing masters, and there is no central master or any order of device priority on the bus. Any device connected to the I<sup>2</sup>C bus is allowed to become a master, but devices are not supposed to "steal" the bus from other devices when a transfer is in process. If a device wishing to be a Master is aware that a transaction (initiated by another master) is taking place, it will wait until the transfer is concluded with a Stop condition on the bus-and only then try to seize it by sending its own Start. It is possible, however, that two or more masters may want to start a transfer at exactly the same moment. A scenario that may happen quite frequently in a loaded system: two devices are waiting for a long transaction to be completed, and simultaneously try to get the bus when detecting the Stop condition. An arbitration procedure synchronizes the different clocks, ensuring that the data is not corrupted, and causes all masters except one to withdraw from the bus, so only one master will control the transfer. This procedure applies only when masters initiate transfers simultaneously. The clock synchronization, illustrated in Figure 10, ensures that only one defined clock is generated on the bus. It occurs naturally, as a result of the wired-AND property of the SCL line. Suppose two masters want to initiate a transfer on the bus. Clk1 and Clk2 in Figure 10 illustrate the desired clock outputs of each device, which would actually occur on the bus if each were the only master. The SCL waveform is the resulting wired-AND of the two clocks. The device that pulls the SCL down first will succeed. The other masters continuously monitor the clock line, and reset their internal clock counter to start counting their own Low clock period. This way, the first falling edge will synchronize all clock generators to the beginning of the Low time. Once a device clock has gone Low it will hold the SCL line in this state until its internal clock High state is reached, and then will release the line. The Low to High change in this device will not change the state of the SCL line if another device, which is still within its Low period, is pulling down the line. This way, SCL will be held Low by the device with the longest Low period. A master that has finished its Low time earlier will enter a wait state until SCL is released by the slowest master and goes high. Upon the rising edge of SCL all masters start counting their High period, the first device to complete its High period will pull the SCL Low. In this way a single, synchronized clock is generated on the bus where the rising edge is being defined by the slowest master and the falling edge by the fastest master. Arbitration between masters takes place on the SDA line. A master which tries to transmit a High while another device transmits a Low will withdraw, shutting off its data output stage and not interfering with the transfer until a Stop condition is detected. Due to the wired-AND property of the SDA line, a device "knows" that it lost arbitration by the fact that the Low SDA is different than its desired High output. Arbitration starts by comparing the address bits. When masters transmit different addresses the one transmitting the address with the lowest binary value wins. If all masters in arbitration transmit to the same address, arbitration continues into ## Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 the comparison of data. Figure 11 illustrates the arbitration process between two masters. By definition, the transfer that forces the wired-AND result is the one that wins the arbitration, so the address and data of a winning device are not corrupted and no information is lost in the arbitration process. A master losing arbitration may generate clock pulses until the end of the byte. Thus it may affect the clock speed, but not the data on the bus. If a master loses arbitration during the addressing stage it is possible that the winning master is trying to address it. In an efficient design, the losing master should switch immediately to its slave receiver mode, receive the data transmitted and acknowledge it—otherwise the message will have to be re-transmitted or is lost. A well designed master will take into account "illegal" protocol situations and will determine that it lost arbitration when it detects a Stop or a Start which are not synchronized with its own transmission. Electrical interference or a malfunctioning device may cause such a situation which actually corrupts the message transfer. ## HANDSHAKE BY CLOCK SYNCHRONIZATION The clock synchronization mechanism as described above actually implements a handshake mechanism, enabling receiving devices to "slow down" fast transfers when necessary. On the bit level, a slow slave device like a microcontroller that does not have hardware I<sup>2</sup>C interface port, can extend each clock period and slow down the bus clock. The speed of any master is adapted to the operating rate of this device as long as it is active on the bus. On the byte level the synchronization mechanism takes effect as a "handshake" mechanism when a slave device that was fast enough to receive or transmit a byte still needs extra time to store the received byte or prepare the next byte for transmission. The slave can hold the SCL line low after the reception and acknowledge of a byte, thus forcing the Master into a wait state—until the slave is ready for the next transfer. ## 8XC751 I<sup>2</sup>C HARDWARE The on-chip I<sup>2</sup>C bus hardware support of the 8XC751 allows operation on the bus at full speed and simplifies the software needed for effective communications on the network. The hardware activates and monitors the SDA and SCL lines, performs the necessary arbitration and framing error checks, and takes care of clock stretching and synchronization. The hardware support includes a bus timeout timer, called Timer I. The hardware is synchronized to the software either through polled loops or interrupts. Two of the port 0 pins are multi-functional. When the $I^2C$ is active, the pin associated with P0.0 functions as SCL, and the pin associated with P0.1 functions as SDA. These pins have an open drain output. Two of the five interrupt sources may be used for I<sup>2</sup>C support. The I<sup>2</sup>C interrupt is enabled by the EI2 flag of the interrupt enable register, and its service routine should start at address 023h. An I<sup>2</sup>C interrupt is usually requested (if enabled) when a rising edge of SCL indicates new data on the bus or a special condition occurs: Start, Stop or arbitration loss. The interrupt is induced by the ATN flag, (see below for the conditions for setting this flag). The Timer I overflow interrupt is enabled by the ETI flag, and the service routine starts at 018h. The I<sup>2</sup>C port is controlled through four special function registers: I<sup>2</sup>C Control (I2CON), I<sup>2</sup>C Configuration (I2CFG), I<sup>2</sup>C Data (I2DAT) and I<sup>2</sup>C Status (I2STA). The register addresses are shown in the 8XC751 section of the Philips Semiconductors Microcontroller Data Handbook (IC20). Although the following discussion of the hardware and register details is not complete, it should give a better understanding of the programming examples. ### Timer In I<sup>2</sup>C applications, Timer I is dedicated to the port timing generation and bus monitoring. In non-I<sup>2</sup>C applications, it is available for use as a fixed rate timer. For the bus monitoring function, Timer I is being used as a "watchdog timer" for bus hang-ups. It creates an interrupt when the SCL line stays in one state for an extended period of time between a Start condition and a following Stop condition. SCL "stuck low" indicates a faulty master or slave. SCL "stuck high" may mean a faulty device or that noise induced into the I<sup>2</sup>C caused all masters to withdraw from the I<sup>2</sup>C arbitration. The time-out interval of Timer I is fixed: it carries out and interrupts (if enabled) when about 1024 machine cycles have elapsed since a change on SCL within a frame. In other words, whenever I<sup>2</sup>C is active we let Timer I run, but clear it whenever a frame is not in progress (reset or Stop occurred more recently than the last Start condition) or SCL changes within a frame. (Note: we wrote "about 1024 machine cycles" for the sake of accuracy—this number may slightly change according to the setting of the CTO and CT1 bits mentioned below. In any case, the exact number of cycles for a time out does not have any practical significance). In addition to the interrupt upon Timer I overflow, the I<sup>2</sup>C port hardware is reset. This is useful for multiple master systems in situations where this same 8XC751 caused the bus hang-up due to a lack of software response. SCL will be released and I<sup>2</sup>C operation between other devices could continue. ### **12CON Register** The I<sup>2</sup>C Control register can be read or written to (see Figure 12). When writing to the I2CON register one should use bit masks as demonstrated in the examples. Trying to clear or set the bits in the register using the bit addressing capabilities of the 8XC751 may lead to undesirable results. The reason is that a command like CLRB reads the register, sets the bit and writes it back—and the write-back may affect other bits. ### **12CFG Register** The configuration register is a read/write register (see Figure 13). ### **I2DAT Register** The I<sup>2</sup>C data register is a read/write register, where the msb represents the data received or data to be sent. The other seven bits are read as 0 (see Figure 14). ### **12CSTA Register** The I<sup>2</sup>C STAtus Register is a read-only register reflecting the internal status of the I<sup>2</sup>C interface hardware (see Figure 15). ### **Transmit Active State** The transmit active state—Xmit Active—is an internal state in the I<sup>2</sup>C interface that is affected by the I<sup>2</sup>C registers as explained above. The I<sup>2</sup>C interface will only drive the SDA line low when Xmit Active is set. Xmit Active is set by writing the I2DAT register or by writing I2CON with XSTR = 1 or XSTP = 1. The ARL bit will be set to 1 only when Xmit Active is set—in such a case Xmit Active will be automatically reset upon ARL. Xmit Active is cleared by writing 1 to CXA at I2CON register or by reading the I2DAT register. AN430 **I2CON READ** RDAT ATN DRDY ARL STR STP MASTER Received DATa bit. The value of SDA latched by the rising edge of SCL. Its contents is identical to RDAT in the RDAT I2DAT register. Reading the received data here allows doing so without clearing DRDY and releasing SCL. An "ATteNtion" flag, set when any one of DRDY, ARL, STR or STP is set. This flag allows a single bit testing for ATN terminating "wait loops", indicating a meaningful event on the bus. This flag also activates the I2C interrupt request. Data ReaDY flag. Set by a rising edge of SCL when I2C is active, except at an idle slave. This flag is cleared by DRDY reading or writing the I2DAT register, or by writing a 1 to CDR (at the same address, when I2CON is written). ARbitration Loss flag. Indicates that this device lost arbitration while trying to take control of the bus. ARL STaRt flag. Set when a Start condition is detected, except at an idle slave. STR STP SToP flag. Set when a Stop condition is detected, except at an idle slave. MASTER This flag is set when the controller is a bus master (or a potential master, prior to arbitration). **I2CON WRITE** CXA IDLE CDR CARL **CSTR** CSTP XSTR XSTP CXA "Clear Xmit Active". Writing a 1 to CXA clears the internal transmit-active state. IDLE Setting this bit will cause a slave to enter idle mode and ignore the I<sup>2</sup>C bus until the next Start is detected. If the software sets the MASTRQ flag, the device may stop idling by turning into a master. CDR Clear Data Ready. Clears the DRDY flag. Clear Arbitration Lost. Clears the ARL flag. CARL **CSTR** Clear STaRt. Clears the STR flag. **CSTP** Clear STop. Clears the STP flag. "Xmit repeated STaRt". Writing a 1 to this bit causes the hardware to issue a Repeated Start signal. A side effect **XSTR** will be setting the internal Xmit Active state. This should be used only when the device is a master. "Xmit SToP". Issues a Stop condition. The Xmit active state is set. **XSTP** SU00368 Figure 12. I2CON Register SLAVEN MASTRQ CLRTI TIRUN CT1 CT0 SLAVEN Writing a 1 to this flag enables the slave functions of the I<sup>2</sup>C interface. MASTRQ Request control of the bus as a master. CLRTI Clear the Timer I interrupt flag. This bit is always read as 0. TIRUN Writing a 1 will let Timer I run. When I2C is active, it will run only inside frames, and will be cleared by SCL transitions, Start and Stop. Writing a 0 will stop and clear the timer. CT1, CT0 These bits should be programmed according to the frequency of the crystal oscillator used in the hardware. They determine the minimum high and low times for SCL, and are used to optimized performance at different oscillator speeds. SU00369 Figure 13. I2CFG Register ## Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 Figure 14. I2DAT Register Figure 15. I2CSTA Register ## I<sup>2</sup>C COMMUNICATIONS SOFTWARE The software listing demonstrates programming the 8XC751/752 for a multimaster I<sup>2</sup>C environment where the device can be both a Master or a Slave responding to other Masters on the I<sup>2</sup>C network. The bulk of the software is communications routines which are not only for demonstration but could be ported to other user programs with minimal or no modifications. The routines are quite general and could be useful in most applications. We have tried to design a well-defined software interface, enabling most users to copy the routines as they are, modifying only the pre-defined interface elements to fit the specific applications. We encourage users to use the routines without modifications whenever possible, as the lower levels of the hardware-software integration could be quite involved. The rest of this application note will relate to the programming example. We shall discuss the general operation of the routines and how they are integrated into an application. Then we shall describe in detail all the software interface elements and how to use them. ## I<sup>2</sup>C COMMUNICATIONS ROUTINES—OVERVIEW In order to function well in a multimaster environment the microcontroller must be able to take control of the I<sup>2</sup>C bus as a Master, "tolerate" message transactions between other Masters and other devices, and respond efficiently as a Slave to other bus Masters. The communications routines should allow a Master "graceful" recovery from an arbitration loss and other situations when a message transaction is not completed, allowing for communication re-tries. For Slave operation the microcontroller must be interrupt driven relative to an I2C frame Start, as any Master on the bus could request a transaction at any moment, not synchronized to the application program executing on the controller. An interrupt service routine monitors the address transmitted on the bus. When the microcontroller is addressed it takes care to either read the data from the bus into a buffer or write buffer data onto the bus. When such a transaction is successfully completed, one of several "Slave Event Routines" is called prior to returning to the main application program. Such an "Event Routine" is a part of the application, allowing an immediate response to the data received, or the fact that data was transmitted to a requesting Master. This allows "synchronization" of the application to a "slave" bus transaction. Typical uses of the Event Routine mechanism will be a computation based on new data, or re-loading the transmit buffer with new data getting ready for the next random request. The actual Event Routines will be programmed differently for different applications, but the names and the calls will remain the same as long as the communications routines are left unmodified. A transaction as a Master is initiated by the application program. Our implementation uses the interrupt mechanism for the Master communications as well. The application issues a request for the bus by setting the MASTRQ bit of the I<sup>2</sup>C port control, and when the bus is available an interrupt occurs. This way, if the bus is free there will be an immediate response. If the bus is busy, the application may go on executing (if so programmed) until this controller can get control of the bus. When the microcontroller gets mastership of the bus it initiates a bus transaction according to "directives" set by the 1992 Jun 26 ## Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 application program. The most important directives are the address (and subaddress if relevant) of the slave device addressed, and the length of the message to be transmitted or received. When a Master transaction is concluded, a Master Event Routine (called MastNext) is called to perform whatever task the application demands. As with the Slave Event Routines it will typically respond to a successful transmission or reception of data. In addition, it could handle situations where a slave does not respond at all, or does not acknowledge a data byte (thus causing data transfer to terminate). A program might react to the fact that a slave does not respond by re-trying to communicate at a later time, by issuing a message to another peripheral device or just ignoring it. The handling of such cases is application dependent, and should be programmed into the routine called "MastNext". The MastNext routine is invoked when the Master terminates the transaction "willingly", but not upon arbitration loss. The microcontroller operating as a bus Master may lose arbitration to another Master which happens when two Masters transmit in synchronization, commencing with the same Start signal. If arbitration is lost while transmitting or receiving data, our processor withdraws from the bus and turns itself into a slave—an active Slave upon a Start, or returning to the calling program as an idle slave. When the arbitration loss occurs while transmitting an address, our processor turns itself immediately into an active slave, "listening" to the rest of the address transmitted by the new Master. If our processor reads its own address from the bus (as transmitted by the new Master) our processor responds as a willful slave. If this mechanism would not have been implemented, there could be potential inefficiency when a device that happened to be synchronized to another Master loses arbitration, but is not able to respond to the winning device. Another situation for arbitration loss could be a bus exception resulting from a device operating not according to the bus protocol or interference on the bus lines. In addition to "regular" arbitration loss detected with the ARL hardware flag, such a situation may occur with detecting a Start or a Stop in the middle of transmitting an address or data byte. In such a situation the microcontroller withdraws from the bus as well—active Slave upon a Start detection, or returning as an idle slave in other cases. When a Master transaction is terminated by an arbitration loss, the Master Request flag (MASTRQ) of the hardware I<sup>2</sup>C port remains in effect. As a result when the bus gets free, our device will take control, issue a Start, and the transaction that was cut will start again. This restart will happen automatically, without any application involvement (unlike non-acknowledgement, where the MastNext routine determines what shall be done). The $I^2C$ communications routines are structured as an interrupt service routine responding to an $I^2C$ port interrupt upon a frame Start. Within a frame the $I^2C$ processing is continuous, where the $I^2C$ port is polled for hardware response, and the $I^2C$ interrupts are disabled. Other interrupts are enabled during the service routine. The set-up requirements from the mainline program are minimal, and interfacing is done via RAM buffers and some pre defined RAM locations. The lower level interface with the hardware is done inside the service routine, and can typically be ignored by the application programmer. ### **BUS WATCHDOG AND ERROR RECOVERY** A malfunctioning device (in hardware or software) may hold the SCL line low, thus causing the bus to be "stuck". It might even be possible that a transient protocol violation (due to hardware interference, such as a device turning on) may cause some devices (non programmable, or even microcontrollers which were not carefully programmed) to hold the bus. Since within a frame the bus is software-polled, a "stuck" bus might cause the application software to "hang forever". Here the TIMERI watchdog comes to the rescue, interrupting when there is no bus activity for a long period of time When the I<sup>2</sup>C service routine is interrupted by the watchdog timer, the processing of the current frame is not completed and the event routines are not called. The software returns to execute the mainline application, and will be interrupted again for the next frame (next Start, received as a slave or induced as a Master). A status flag and a counter report on the watchdog interrupt, so the application program can be made to inhibit the I<sup>2</sup>C port if there are too many occurrences of a "hanging" bus. Bus protocol errors and "hangups" might be an issue in systems which are susceptible to noise, temporary bus line shorts, "hot plug in" of devices or even erroneously programmed devices—and a "fail safe" controller program should be able to detect bus problems and possibly assist in resolving them. The RECOVER routine resets the I<sup>2</sup>C interface of the microcontroller, and attempts to release some other devices on the bus by toggling the clock line. The I<sup>2</sup>C interface of the 8XC751 is reset by letting Timerl run and expire, since this circuitry does not feature a software controlled reset. This "extreme" measure is needed in some cases of bus protocol violation. The bus and interface circuit recovery routine can be automatically invoked whenever Timerl detects a timeout. In addition, for systems where potential bus failures are a concern and reliability is an issue, one may implement mechanisms to invoke bus and interface recovery from the application code. This may help in cases where the bus gets "stuck" when there is no I2C frame in progress. In such an instance the watchdog timer will not give any timeout indications. as it has not been activated. Another case emanates from a design peculiarity of the interface circuitry on the 8XC751: if the SCL line is externally grounded when there is a Start condition, this Start might be ignored, and the watchdog may not be activated. Our programming example deals with potential failures by testing for transaction completion and retrying transmissions when necessary (these are explicit retries, in addition to an "automatic" retry after a Master's arbitration loss, invoked by the MASTRQ bit). Too many transmission failures activate the RECOVER routine. ## Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 ### 12C COMMUNICATIONS ROUTINES—INTERFACE The I<sup>2</sup>C service routine deals with the transmission and reception of messages, without any concern for the contents of the message. In order to provide a general interface for different applications the data is transferred via buffers. The service routine does not have to "know" where the data goes to or comes from—as long as the application program specifies the required pointers for these buffers. The interface to the actual application (which "cares" about message contents, timing, addressing and so forth) is done in a well defined manner, allowing usage of the same service routine with different application programs. The interface is carried out with the use of buffers, pre-defined names for Application Event Routines, interface RAM locations for transferring parameters, pointers and flags, and constants. A more detailed discussion of the interface follows. ### **Buffers** There are three buffers for data transfers between the I<sup>2</sup>C bus and the application program. MasBuf is used for Master transmission and reception. The number of data bytes for each Master message—reception or transmission, is specified by the memory location MASTCNT. The value in MASTCNT should be less than the length of MasBuf. For Master transmission the message is placed in MasBuf before the transmission is initiated. In Master reception, the received message will be contained in the same buffer. There is only one Master message transaction occurring at the same time, so we may use the same buffer both for transmission and reception. For Slave operation we must accommodate data transfers which may come randomly, asynchronous to each other or to possible operation of the same device as a Master. Therefore it is necessary to allocate additional RAM area as buffers dedicated to Slave operation: SRcvBuf for receiving data, STxBuf for transmission. The length of the Slave receive buffer is defined by the symbol RBufLen. It is used by the code for protection, avoiding overwriting RAM beyond the allocated buffer size in case a Master sends a message which is too long. There is no need for RAM protection for transmission, but the Master should not request more data than STxBuf can supply. ### **Interface RAM Locations** RAM location MyAddr contains the address of this processor. Status flag MSGSTAT is used for reporting to the application on I<sup>2</sup>C communications status—mainly on the successful, or unsuccessful, completion of a message transaction. The contents of MSGSTAT may be used by the mainline application code or by the Event Routines. The different codes that could be placed by the I<sup>2</sup>C service routine are described later in the text. When the message processing commences, a code indicating Slave or Master processing is inserted to MSGSTAT, and is updated as we go along. There could be many applications that will not need to use MSGSTAT contents, as the very fact of calling a certain event routine implies completion of a processing stage. For Master transactions, in addition to the data buffer MasBuf, there are several RAM locations into which the application inserts Master message "directives". These directives provide the service routine with the information necessary to carry out the next Master transaction. The one byte RAM locations used for directives are DESTADRW, DESSUBAD, MASTONT and MASCMD. DESTADRW contains the destination slave address in bits 7-1, while bit 0 is the R/W bit. Bit 0 contains 0 for a Write operation (the message is to be transmitted to the salve) and 1 for a Read operation (message is being read from the slave and received by this Master). DESSUBAD contains the 8 bit sub-address of the slave, if necessary. For transactions without a sub-address, the contents of DESSUBAD is ignored. MASTCNT contains the number of data bytes in the message to be sent from or received into MasBuf. This number should not be bigger than the length of MasBuf. MASCMD byte contains the bit flags SUBADD, RPSTRT and SETMRQ. SUBADD is 0 (cleared) for a message with a regular address, and 1 (set) when a subaddress is required. When SUBADD is set, the service routine takes care of all the protocol required for sub-addressing, which includes a Repeated Start for Read operations. A message with a subaddress is considered to be a single message, even if it includes a Repeated Start. The RPSTRT and SETMRQ are kept cleared in regular applications, and will be used only for "tailoring" the bus transfers in special cases. When RPSTRT is cleared the message will terminate, as usually required, with a Stop. When RPSTRT is set a Repeated Start will be sent on the bus, and Master operation will resume. The RPSTRT directive relates to terminating the message after all the data was transferred, and not to the mandatory Repeated Start in the middle of sub-addressed Read operation. A single message with a subaddress will typically have RPSTRT cleared. SETMRQ indicates what will be loaded into the MASTRQ flag of the hardware when Stop is transmitted. Typically it will be cleared. When SETMRQ is 1, MASTRQ will be set, thus trying to issue a new Start immediately following the Stop. In such a case the service routine will not return upon Stop, but will continue as a Master. TITOCNT is used to count time-outs of the watchdog timer. Whenever such a timeout invokes the TIMER I interrupt service routine the contents of the location TITOCNT are incremented, and the timeout is reported in MSGSTAT. The count is saturated at 0FFh. This mechanism may be used in an application that is very much "concerned" with potential bus failures, allowing some type of "failure monitoring" by the application even for Slave transactions. AN430 Figure 16. Typical Communications Scenario—A Simplified Diagram ### **APPLICATION EVENT ROUTINES** The service routine calls Event Routines with pre-defined names (Figure 16), and these routines must be provided by the application program. The actual code of the routines will differ from application to application, but the routine names are being kept the same. These routines are being called when successful processing of a message (send or receive) is completed. The routines may perform whatever action the application was designed for, which is not necessarily related to the I<sup>2</sup>C communications mechanism. In addition, the routines may perform the data interface tasks for the I<sup>2</sup>C port, like emptying buffers from received data or preparing the next message by setting up the buffers. The mechanism of calling the event routines out of the service routine allows an immediate reaction to the event of message processing completion, before any new activity happens on the bus. In some simple applications this may not be necessary. For example, one may have a main program for a slave which is just a wait loop monitoring a flag set by the service routine when a message transfer, initiated by some master, is completed. In such a case the application could react to the message completion after the interrupt service routine returns. However, in the general case this will not be sufficient. An example could be a slave with an application which is constantly busy doing another task, in an environment where the communication requests on the I<sup>2</sup>C bus are frequent. If there is a new message request shortly after the current message is completed, having to wait for the application until it "has time" may result in not reacting, or sending the same data again, or overwriting the received data in the buffer. Another obvious case demanding event routine calls is a Master sending different messages with a Repeated Start—the new data for the following message must be prepared in the interrupt service routine as the current message is completed (there is no return from interrupt prior to the new data transmission). The programmer has the flexibility to decide where to prepare the next message according to the requirements of the application. This can be done after return from the event routine, in the application code after the return from interrupt, or a combination of both, where the time critical events are performed in the event routines. The application may monitor the MSGSTAT flag for message processing completion. If the event routines are not used, it is recommended to simply code them as a "RET" instruction, thus turning them into dummy routines (this an easier and better practice than changing the service routine itself, eliminating the calls). Application note ## Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 ### **Master Event Routine:** Philips Semiconductors #### MastNext This routine is called by the service routine when the processing of the current Master message is completed. For an indication on the type of message processing completion, MastNext may inspect the contents of MSGSTAT RAM location. When MastNext is called, MSGSTAT will contain one of the following codes for message processing completion: MRCVED (= 21h)—a complete message (with number of data bytes indicated by MASTCNT) was received from the slave. MTXED (= 22h)—the number of data bytes indicated by MASTCNT were successfully sent and acknowledged by the slave. MTXNAK ( = 23h)—the slave did not acknowledge a data byte of the message, even though it had acknowledged its address. The message transmission was terminated upon the NAK. MTXNOSLV ( = 24h)—no slave acknowledged the address indicated by memory location DESTADDR. The MastNext routine may perform any task(s) necessary for the application. Data handling tasks will typically be dependent on the MSGSTAT indication. One possible task could be setting the directives for the next message. The necessity for executing this task here (versus the main-line code initiating the transfer) is of course application dependent. ### Slave Event Routines: These routines are called when a message transaction as a slave has been completed. In many cases it could be important to utilize the calls to such routines as the requests for message transactions as a slave can come randomly, asynchronous to the application program. The application may demand that new data coming in should immediately initiate some tasks (e.g. control an output port)—and the event routine can be used to process the result of the slave interrupt. In most cases it will be necessary for a slave to react immediately to a message received simply in order not to lose the data. As a new message may come randomly, it may overwrite the reception buffer before the data has been transferred out of it or acted upon. For applications in which the reaction for slave events is performed after the return from the service routine, the event is reported by placing an appropriate code in the MSGSTAT flag. The programmer may use event routines, other mainline routines inspecting MSGSTAT, or both. If the event routines are not used, it is recommended to code them as a "RET" instruction. ### SRcvdR Called by the service routine when a new, complete message has been received into SRcvBuf. When SRcvdR is called, R1 points to the address of the last byte received into the buffer. In a typical application SRcvdR will transfer the new data out of SRcvBuf, so it will not be written over by a subsequent slave reception. The equivalent MSGSTAT indication for this event is SRCVD (= 11h). ### SLnRcvdR Called when a slave message has been received into SRcvBuf, but the message was longer than the SRcvBuf buffer (as specified by RbufLen). The equivalent MSGSTAT indication for this event is SRLNG (= 12h). If the program is supposed to react to a too long a message the same way as to a message that can be contained in the buffer, one may code SLnRcvdR simply as a call to SRcvdR. ### STXedR: Called by the service routine when data has been transmitted out of the slave STxBuf buffer according to a master's request. This routine may insert new data into the buffer, preparing it for the next slave transmission. The equivalent MSGSTAT indication for this event is STXED (= 13h). Note that we do not have a separate routine for the case that the master requested too many bytes—more than STXBuf length—and we sent out meaningless bytes. It is the master's responsibility to specify the message length, and it should be able to request messages with the appropriate length from each slave on the bus. #### SRFrrR This routine relates more to bus communications than to the application itself. It can be called when we positively detect a bus error upon reception as a slave, in case the application is supposed to know about it. In most cases this call will not be used, as dealing with bus communications difficulties is usually left to the Master. Just prior to calling SRErrR, the code SRERR (= 14h) is placed in MSGSTAT. ## 0Completion Routine: I2CDONE This routine is called every time, before returning from the I<sup>2</sup>C interrupt service routine, whether the transaction was successful or not. It can be used to "safely" monitor MSGSTAT without any risk of a new interrupt modifying the current indication. Simple application programs will not make use of this routine. A more sophisticated application implementing a fail-safe communications protocol may use it to count errors of a certain type in order to determine a recovery scheme. In our programming example, I2CDONE inhibits I<sup>2</sup>C interrupts when it is evident that as a result of protocol errors interrupts are not caused by legitimate Starts. ## **CONSTANTS** RBufLen—the length of SRcvBuf, the slave receive buffer. This constant may be used both by the I<sup>2</sup>C routines and the application program, and it is the responsibility of the application programmer to define the correct buffer length. MYNUM—This ROM constant is dependent on the application environment. It is a small integer defining a "serial number" of the node, out of all the processors running the same code. This constant is used only when recovering from a timeout, in order to "de-synchronize" masters from each other when trying to recover the bus CTVAL1 is a constant defined in ROM. It is used by the application code portion which initializes the I<sup>2</sup>C, for loading CT0 and CT1 with a value appropriate for the crystal being used. MYADDR1 is a ROM constant containing the address of the processor's I<sup>2</sup>C node. This value is used by the application demo to load the RAM location MyAddr. AN430 ## **USING THE COMMUNICATIONS SUBROUTINES** In order to use the I<sup>2</sup>C Communications Routines an application program should take care of the following: - Upon initialization, load bits CT1, CT0 of I2CFG register according to the clock crystal used (refer to the table of CT1, CT0 values in the 8XC751 section of the Philips Semiconductors Microcontroller Data Handbook (IC20)). - Load MyAddr RAM location with the address of this node. - For Slave operation, load STxBuf with the initial data to be transmitted - For slave operation, set the SLAVEN bit in the I2CFG register. - Enable I<sup>2</sup>C and watchdog interrupts by setting the ETI, EI2 and EA bits of the interrupt enable register. - For Master operation, set up the next transaction by loading the appropriate directives into MASCMD, DESTADRW, DESSUBAD (if applicable) and MASTCNT, and load MasBuf with the appropriate data if it is a Write message. - For Master operation, initiate the next transaction by setting MASTRQ bit in I2CFG. - For both Master and Slave operation, handle data transmission and reception via the buffers in main-line code or the Event Routines. ### PROGRAMMING EXAMPLE The assembler listing includes the I<sup>2</sup>C Communications Routines and a demo application exercising these routines. In most real-life applications the code of the routines could be used without modifications. For those who follow the coding of the routines, one should note that in many instances code speed and program space have been slightly compromised in order to improve readability. The almost "general purpose" interface to the routines affects efficiency as well, and it is possible to write more compact and somewhat faster code for specific applications. The reader is encouraged, though, to use the code "as is" whenever possible. The "application" demo is simple—two microcontrollers exchange messages in a "ping-pong" game. In addition to trivial message exchange, the code demonstrates recovery mechanisms from communications errors and bus "hangups". We tried this code with two pairs of controllers exchanging messages on the same bus. The message exchange could repeatedly recover and restart when the SCL and SDA lines were temporarily shorted to ground or between themselves. Simpler versions, without the "protection" mechanisms, could "hang up" under such conditions. ### Source Code Available On BBS The source code file for this program is available for download from the Philips computer bulletin board system. This system is open to all callers, operates 24 hours a day, and can be accessed with modems at 2400, 1200, and 300 baud. The telephone numbers for the BBS are: (800) 451-6644 (in the U.S. only) or (408) 991-2406. ## AN430 | PPCODE1 | 83C | 2751 Multimaster I2C I | Routines | | | 4/14/1992 | PAGE 1 | |---------|-----|-----------------------------------------|---------------|--------------|------------------------------|----------------|----------------------| | | 1 | <b>;</b> | | | | | | | | 2 | | | | | | | | | 3 | ******** | ***** | ****** | ******* | ***** | ***** | | | 4 | | Multimas | ster Code f | for 83C751/83C752 | | | | | 5 | | 4/14/199 | | | | | | | 6 | ,<br>.********* | | | ******* | ***** | ***** | | | 7 | | | | y an application note. The | | | | | 8 | | | | d transportable into differe | | | | | | | | | T optimized for speed and | | | | | 9 | | narios, and | wele NO | 1 optimized for speed and | nor memory | An art of the first | | | 10 | ; utilization. | | | | | | | | 11 | , | | | | | | | | 12 | ; Yoram Arbel | | | | | | | | 13 | | | **** | | | ration of the second | | | 14 | \$TITLE(83C751 | | ster I2C R | outines) | | | | | 15 | \$DATE(4/14/19 | 92) | | | | | | | 16 | \$MOD751 | | | | | | | | 17 | \$DEBUG | | | | | | | | 18 | | | | | | | | | 19 | ******** | ***** | ***** | ******* | ****** | ***** | | | 20 | <b>;</b> | 8XC751 | MULTIM | ASTER I2C COMMUNIO | CATIONS ROUTIN | ES | | | 21 | • | Symbols | and RAM | definitions | | | | | 22 | ******** | ****** | ****** | ******* | ****** | ***** | | | 23 | | | | | | | | | 24 | ; Symbols (masl | ks) for I2C | FG bits. | | | | | | 25 | , -, | ., | | | | | | 0010 | 26 | BTIR | EQU | 10h | ; TIRUN bit. | | | | 0040 | 27 | BMRQ | EQU | 40h | ; MASTRQ bit. | | | | 0040 | 28 | Billing | 200 | .011 | , | | | | | 29 | | | | | | | | | 30 | ; Symbols (masl | ke) for I2C | ON hite | | | | | | | , Symbols (mass | KS) 101 12C | OI Voits. | | | | | 0000 | 31 | DOVA | EOU | 904 | . CVA hit | | | | 0080 | 32 | BCXA | EQU | 80h | ; CXA bit. | | | | 0040 | 33 | BIDLE | EQU | 40h | ; IDLE bit. | | | | 0020 | 34 | BCDR | EQU | 20h | ; CDR bit. | | | | 0010 | 35 | BCARL | EQU | 10h | ; CARL bit. | | | | 8000 | 36 | BCSTR | EQU | 08h | ; CSTR bit. | | | | 0004 | 37 | BCSTP | EQU | 04h | ; CSTP bit. | | | | 0002 | 38 | BXSTR | EQU | 02h | ; XSTR bit. | | | | 0001 | 39 | BXSTP | EQU | 01h | ; XSTP bit. | | | | | 40 | | | | | | | | | 41 | ; Note: | | | | | | | | 42 | ; | | | | | | | | 43 | ; Specific bits o | f the I2CO | N register | are set by writing into this | s register a | | | | 44 | ; combination o | f the mask | s defined a | above using the MOV con | nmand. | | | | 45 | ; The SETB cor | mmand sho | ould not be | used with I2CON, as it is | implemented by | | | | 46 | ; reading the co | ntents of th | ne register, | setting the appropriate bi | t and | | | | 47 | | | | the functionality of the Re | | | | | 48 | | | _ | er is different, using SETI | | | | | 49 | • | | | | -, | | | | 50 | • • • • • • • • • • • • • • • • • • • • | .11. | | | | | | | 51 | | action state | ne indicati | ons in MSGSTAT: | | | | | | , , | activit stati | us muicali | one in MisosiAI. | | | | 0010 | 52 | | EOH | 105 | . Storted Slave masses | ra progassi | | | 0010 | 53 | SGO | EQU | 10h | ; Started Slave messag | ge processing. | | 118 AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | 4/14/1992 PAGE 2 | |---------|----------|-------------------|----------|-------|---------------------------------------------------------| | 0011 | 54 | SRCVD | EQU | 11h | ; as a slave, received a new message | | 0012 | 55 | SRLNG | EQU | 12h | ; received as slave a message which is too | | | 56 | | | | ; long for the buffer | | 0013 | 57 | STXED | EQU | 13h | ; as slave, completed message transmission. | | 0014 | 58<br>59 | SRERR | EQU | 14h | ; bus error detected when operating as a slave. | | 0020 | 60 | MGO | EQU | 20h | ; Started Master message processing. | | 0021 | 61 | MRCVED | EQU | 21h | ; As Master, received complete message from | | | 62 | | | | ; slave. | | 0022 | 63 | MTXED | EQU | 22h | ; As Master, completed successful message | | | 64 | | | | ; transmission (slave acknowledged all data | | | 65 | | | | ; bytes). | | 0023 | 66 | MTXNAK | EQU | 23h | ; As Master, truncated message since slave did | | | 67 | | | | ; not acknowledge a data byte. | | 0024 | 68 | MTXNOSLV | EQU | 24h | ; AS Master, did not receive an acknowledgement | | | 69 | | | | ; for the specified slave address. | | | 70 | | | | ing <u>alago</u> ng kaji alawa na Misa di Marana di | | 0030 | 71 | TIMOUT | EQU | 30h | ; TIMERI Timed out. | | 0032 | 72 | NOTSTR | EQU | 32h | ; Master did not recognize Start. | | | 73 | | | | | | | 74 | | | | ; RAM locations used by I2C interrupt service routines. | | | 75<br>75 | | | | | | 0000 | 76 | ) ( ) ( ) ( ) ( ) | D. 100. | 201 | | | 0020 | 77 | MASCMD | DATA | 20h | | | 0000 | 78<br>70 | SUBADD | BIT | MASCN | | | 0001 | 79 | RPSTRT | BIT | MASCN | | | 0002 | 80<br>81 | SETMRQ | BIT | MASC | MD.2 | | 0024 | 82 | DSEG | AT | 24h | | | | 83 | DOLO | 711 | 2-411 | | | 0024 | 84 | MSGSTAT: | DS | 1 | ; I2C communications status. | | 0025 | · 85 | MYADDR: | DS | 1 | ; Address of this I2C node. | | 0026 | 86 | DESTADRW: | DS | 1 | ; Destination address + R/W (for Master). | | 0027 | 87 | DESSUBAD: | DS | 1 | ; Destination subaddress. | | 0028 | 88 | MASTCNT: | DS | 1 | ; Number of data bytes in message (Master, | | | 89 | | | | ; send or receive). | | | 90 | | | | | | 0029 | 91 | TITOCNT: | DS | 1 | ; Timer I bus watchdog timeouts counter. | | 002A | 92 | StackSave: | DS | 1 | ; SP save location (used when returning from | | | 93 | | | | ; bus recovery routine). | | | 94 | | | | | | 002B | 95 | MasBuf: | DS | 4 | ; Master receive/transmit buffer, 8 bytes. | | 002F | 96 | SRcvBuf: | DS | 4 | ; Slave receive buffer, 8 bytes. | | 0033 | 97 | STxBuf: | DS | 4 | ; Slave transmit buffer, 8 bytes. | | | 98 | | | | | | | 99 | | | | | | | 100 | | | | | | 0004 | 101 | RBufLen | EQU | 4h | ; The length of SRcvBuf | | | 102 | | | | | AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | | | 4/14/1992 | PAGE 3 | |-----------|--------|------------------|---------------|-------------------|-----------------------------------------|---------------|-----------|--------| | | 103 | ********* | ****** | ***** | ***** | ****** | ***** | | | | 104 | | APPLICA | ATION ou | tput pins and RAM | definition | s | | | | 105 | ******** | | | ***** | | | | | | 106 | | | | | | | | | | 107 | ; Outputs used b | v the appli | cation: | | | | | | | 108 | , | | | | | | | | 0090 | 109 | TogLED | BIT | P1.0 | ; Toggling outpu | it pin, to co | onfirm | | | | 110 | | | | ; that the ping-p | | | | | 0091 | 111 | ErrLED | BIT | P1.1 | ; Error indicatio | | | | | | 112 | | | | 7 | | | | | 0093 | 113 | OnLED | BIT | P1.3 | ; | | | | | 0070 | 114 | | | | | | | | | | 115 | ; Application R | AM | | | | | | | | 116 | , | | | | | | | | 0021 | 117 | APPFLAGS | DATA | 21h | | | | | | 0008 | 118 | TRQFLAG | BIT | APPFI | LAGS.0 | | | | | ,0000 | 119 | ; Flag for monit | | | | | | | | 0009 | 120 | SErrFLAG | BIT | | LAGS.1 | | | | | 0007 | 121 | D2111 2110 | 7 ( ) ( ) ( ) | | 100 | | | | | 0037 | 122 | FAILCNT: | DS | 1 | | | | | | | 123 | THE CIVI. | | | | | | | | 0038 | 124 | TOGCNT: | DS | 1 | ; Toggle counter | r. | | | | 0036 | 125 | roceiti. | | • | , 108810 0001110 | | | | | | 126 | | | | | | | | | | 127 | ******** | ***** | ***** | ****** | ***** | ***** | | | | 128 | | | | | | | | | | 129 | • | Program | Start | | | | | | | 130 | • | Trogram | Juni | | | | | | | 131 | ,<br>.********* | ***** | ****** | ******* | ***** | ***** | | | | 132 | CSEG | | | | | | | | | 133 | CSEG | | | | | | | | | 134 | ; Reset and inte | rrunt vecto | re | | | | | | | 135 | , reset and me | Trupt vecto | | | | | | | 0000 4178 | 136 | AJMP | Reset | | ;Reset vector at | address 0. | | | | 0000 4170 | 137 | | 110001 | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | | | | 138 | | | | | | | | | | 139 | ; A timer I time | out usually | indicates | a 'hung' bus. | | | | | | 140 | 1 | out usuuri, | | | | | | | 001B | 141 | ORG | 1Bh | | ; Timer I (I2C t | imeout) int | errupt. | | | 001B D2DD | 142 | TimerI: | SETB | CLRT | | | | | | 001D 4111 | 143 | АЈМР | TIISR | | ; Go to Interrup | t Service R | outine. | | | 0012 1111 | 144 | | | | , | | | | | | 145 | | | | | | | | | | 146 | | | | | | | | | | 147 | | | | | | | | | | 148 | ******* | ******* | ****** | ****** | ***** | ****** | ***** | | | 149 | • | I2C Inte | rrunt Serv | rice Routine | | | | | | 150 | ,<br>.******** | | | *********** | ****** | ****** | ***** | | | 151 | , | | | | | | | | | 152 | , Notes on the | interrunt me | echanism. | | | | | | | 153 | , motes on the | orrapt III | - J.I.G.III 5111. | | | | | | | 154 | · Other interru | nts are enah | led during | this ISR upon retu | ırn from XI | RETI. | | | | 155 | ; Limitations in | | _ | - | /11 | | | | | 133 | , Limitations ii | iiposcu oii t | June 10IX | · | | | | | PPCODE1 | 83C75 | I Multimaster I2C | Routines | | | 4/14/1992 | PAGE 4 | | | | |-------------|-------|-------------------|---------------------------------------------------------------------------|-----------|-----------------------|------------------------|------------------------|--|--|--| | | 156 | ; - Should not l | e long (close | to 1000 | clock cycles). | A long ISR will cause | | | | | | | 157 | | | | I interrupt to occur. | | | | | | | | 158 | | | | the same mechanism | | | | | | | | 159 | further interruj; | ;further interrupts, or if they do - disable TIMERI interrupt beforehand. | | | | | | | | | | 160 | ; | | | | | | | | | | | 161 | ; The 751 hards | ; The 751 hardware allows only one level of interrupts. We simulate an | | | | | | | | | | 162 | ; additional lev | el by software | by perf | forming a RETI inst | ruction (at location | | | | | | | 163 | ; XRETI) the ir | terrupt-in-pro | ogress fl | ip-flop is cleared, a | nd other interrupts | | | | | | | 164 | ; are enabled. | The second | level of | interrupt is a must | n our implementation, | | | | | | | 165 | ; enabling time | out interrupts t | o occur | during "stuck" wait | loops in the I2C | | | | | | | 166 | ; interrupt servi | ce routine. | | | | | | | | | | 167 | | | | | | | | | | | | 168 | | | | | | | | | | | 0023 | 169 | ORG | 23h | | | | | | | | | | 170 | | Say Lating | | | | | | | | | 0023 C2AC | 171 | I2CISR: | CLR | EI2 | ; Disable I2C inte | rrupt. | | | | | | 0025 114C | 172 | ACALL | XRETI | | ; Allow other inte | rrupts to occur. | | | | | | 0027 C0D0 | 173 | PUSH | PSW | | | | | | | | | 0029 C0E0 | 174 | PUSH | ACC | | | | | | | | | 002B E8 | 175 | MOV | A,R0 | | | | | | | | | 002C C0E0 | 176 | PUSH | ACC | | | | | | | | | 002E E9 | 177 | MOV | A,R1 | | | | | | | | | 002F C0E0 | 178 | PUSH | ACC | | | | | | | | | 0031 EA | 179 | MOV | A,R2 | | | | | | | | | 0032 C0E0 | 180 | PUSH | ACC | | | | | | | | | | 181 | | | | | | | | | | | 0034 85812A | 182 | MOV | StackSave, | SP | | | | | | | | 0037 C2DC | 183 | CLR | TIRUN | | | | | | | | | 0039 D2DC | 184 | SETB | TIRUN | | | | | | | | | | 185 | | | | | | | | | | | 003B 209A09 | 186 | JB | STP,NoGo | | | | 100 | | | | | 003E 30990C | 187 | JNB | MASTER, | | | | | | | | | 0041 752420 | 188 | MOV | MSGSTAT, | #MGO | | | | | | | | 0044 209B76 | 189 | JB | STR,GoMa | ster | | | | | | | | 0047 752432 | 190 | NoGo: | | MSGST | AT,#NOTSTR | | | | | | | 004A 21AE | 191 | AJMP | Dismiss | | ; Not a valid Start | • | | | | | | 00467.00 | 192 | | | | | | | | | | | 004C 32 | 193 | XRETI: | RETI | | | | | | | | | | 194 | | | | | | $\mathbf{v}_{\lambda}$ | | | | | | 195 | ·************ | ***** | ***** | ****** | ****** | ***** | | | | | | 196 | ; | | | Receive Routines | | | | | | | | 197 | ;************ | ***** | ***** | ****** | ******* | ***** | | | | | | 198 | | | | | | | | | | | | 199 | i y Bu so | SLAVE CO | | | | | | | | | | 200 | ; | GET THE A | ADDRES | SS | | | | | | | 0045 550440 | 201 | | | | | | | | | | | 004D 752410 | 202 | GoSlave: | | | AT,#SGO | | | | | | | 0050 31E2 | 203 | AddrRcv: | | ClsRcv8 | | | | | | | | 0052 309D5E | 204 | JNB | DRDY, SM | sgEnd | | ange Start or Stop | | | | | | | 205 | | | | | ss byte was completed. | | | | | | 0055 1050 | 206 | Am | -122 | | ; Not a valid addre | | | | | | | 0055 A2E0 | 207 | STstRW: | | C,ACC. | 0; Save R/W~ bit it | | | | | | | 0057 C2E0 | 208 | CLR | ACC.0 | | ; Clear that bit, lea | iving "raw" address | | | | | | | | | | | | | | | | | AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | | 4/14/1992 | PAGE 5 | |-------------|--------|-----------------|-----------------|--------------|--------------------------|----------------------------|--------| | 0059 6060 | 209 | JZ | Goldle | ; If it is a | General Address | | | | | 210 | | | ; - ignore | it. | | | | | 211 | | | | | | | | | 212 | | | ; NOTE: | | | | | | 213 | | | ; One ma | y insert here a differe | nt | | | | 214 | | | | nt for general calls, if | | | | | 215 | | | | e relevant. | | | | | | | | , those the | 0 1010 VIII. | | | | 005D 4007 | 216 | TC | SlvTx | · It's a Da | ead - (requesting slav | <b>A</b> | | | 005B 4027 | 217 | JC | 21417 | ; transmit | | | | | | 218 | | | , transmit | .)• | | | | | 219 | | | | | | | | | 220 | | | | | | | | | 221 | | | | | | | | | 222 | | | | | | | | | 223 | | | ; It is a W | rite (slave should rec | eive the message). | | | | 224 | | | | | | | | | 225 | | | ; Check i | f message is for us | | | | | 226 | | | | | | | | 005D B5255B | 227 | SRcv2: | CJNE | A,MYAD | DDR,GoIdle ; | If not my address - ignor | e the | | | 228 | | | | , | message. | | | 0060 792F | 229 | MOV | R1,#SRcvE | Buf | ; Set receive buffer a | address. | | | 0062 7A05 | 230 | MOV | R2,#RbufL | en+1 | ; | | | | 0064 8002 | 231 | SJMP | SRcv3 | | | | | | 0004 0002 | 232 | 501.11 | | | | | | | 0066 F7 | 233 | SRcvSto: | MOV | @R1 A | ; Store the byte | | | | | 234 | Inc | R1 | CICIAI | ; Step address. | | | | 0067 09 | | SRcv3: | ACALL | AckRcv8 | • | | | | 0068 31ED | 235 | | | | ; Exit loop -end reco | ention | | | 006A 309D09 | 236 | JNB | DRDY,SR | | ; Go to store byte if | | | | 006D DAF7 | 237 | DJNZ | R2,SRcvSt | .0 | , do to stole byte if | buller not run. | | | | 238 | | | | . To a manus byston no | asivad da not aaknowle | lae | | | 239 | | | WODI NO | | ceived – do not acknowled | igc. | | 006F 752412 | 240 | MOV | MSGSTAI | ,#SKLNG | ; Notify main that (a | | | | | 241 | | | | ; have received too l | | | | 0072 7110 | 242 | ACALL | SLnRCvdF | 3. | ; Handle new data – | slave event routine. | | | 0074 8045 | 243 | SJMP | Goldle | | | | | | | 244 | | | | | | | | | 245 | | | | | | | | | 246 | | | | | | | | | 247 | ; Received a by | yte, but not Dl | RDY - ch | eck if a legitimate me | ssage end. | | | | 248 | | | | | | | | 0076 B8072E | 249 | SRcvEnd: | CJNE | R0,#7,Sl | RcvErr ; If bit cou | ant not 7, it was not | | | | 250 | | | | ; a Start o | r a Stop. | | | | 251 | | | | | | | | | 252 | | | | ; Received | d a complete message | | | | 253 | | | | | | | | | 254 | | | | | | | | 0079 752411 | | MOV | MSGSTAT | C#SRCVI | | | | | 00/9 /32411 | 255 | IAIO A | 1412O21A | ., OICC V L | | e number of bytes receive | d | | 0070 50 | 256 | MOV | A D1 | | , Calculat | e number of bytes receive | _ | | 007C E9 | 257 | MOV | A,R1 | | | | | | 007D C3 | 258 | CLR | C | | | of huton in ACC | | | 007E 942F | 259 | SUBB | A,#SRcvE | suI | | of bytes in ACC | .tina | | 0080 51EF | 260 | ACALL | SRCvdR | | ; Handle | new data – slave event rou | iune. | | 0082 802F | 261 | SJMP | SMsgEnd | | | | | 122 1992 Jun 26 | PPCODE1 | 83C75 | 1 Multimaster I2C | Routines | 4/14/1992 | PAGE 6 | |-------------|------------|-------------------|---------------------------------------|---------------------------------------------------------------------|---------| | | 262 | | | | | | | 263 | | | | | | | 264 | | | ; It is a Read message, check if for us. | | | | 265 | | | , it is a Read message, eneck it for us. | | | 0084 00 | 266<br>267 | SlvTx: | NOP | | | | 0085 B52533 | 268 | STx2: | CJNE A,MYADDR. | Goldle; Not for us. | | | 0088 759900 | 269 | MOV | I2DAT,#0 | | | | 008B 309EFD | 270 | JNB | ATN,\$ | ; Acknowledge the address. | | | 008E 309D22 | 271 | JNB | DRDY,SMsgEnd | ; Wait for attention flag. | | | 000200,222 | 272 | 31115 | DKD 1,5WisgLild | ; Exception – unexpected Start<br>; or Stop before the Ack got out. | | | 0091 7933 | 273 | MOV | R1,#STxBuf | ; Start address of transmit buffer. | | | 0093 E7 | 274 | STxlp: | MOV A,@R1 | ; Get byte from buffer | | | 0094 09 | 275 | INC | R1 | , Get byte from buffer | | | 0095 31CE | 276 | ACALL | XmByte | | | | 0097 309D19 | 277 | JNB | DRDY,SMsgEnd | ; Byte Tx not completed. | | | 009A 309FF6 | 278 | JNB | RDAT,STxlp | ; Byte 1x not completed. | | | 009D 759860 | 279 | MOV | I2CON,#BCDR+BIDLE | ; Master Nak'ed for msg end. | | | 00A0 752413 | 280 | MOV | MSGSTAT,#STXED | , Master Nak ed for flisg end. | | | 00A3 7110 | 281 | ACALL | STXedR | ; Slave transmitted event routine. | | | 00A5 21AE | 282 | AJMP | Dismiss | , Glave transmitted event routine. | | | | 283 | 1101711 | Distinss | | | | | 284 | | | | | | 00A7 752414 | 285 | SRcvErr: | MOV MSGSTAT,#S | SRERR ; Flag bus/protocol error | | | 00AA 7110 | 286 | ACALL | SRErrR | ; Slave error event routine. | | | 00AC 8005 | 287 | SJMP | SMsgEnd | , slave citor event routine. | | | 00AE 752414 | 288 | StxErr: | MOV MSGSTAT,#S | SRERR ; Flag bus/protocol error | | | 00B1 7110 | 289 | ACALL | SRErrR | , i lag bus/protocol cirol | | | | 290 | | | | | | 00B3 209903 | 291 | SMsgEnd: | JB MASTER,SM | IsoEnd2 | | | 00B6 209B94 | 292 | JB | STR,GoSlave | ; If it was a Start, be Slave | | | 00B9 | 293 | SMsgEnd2: | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | , in it was a start, so shave | | | 00B9 21AE | 294 | AJMP | Dismiss | | | | | 295 | | | | | | | 296 | | | | | | | 297 | | | ; End of Slave message proce | eccina | | | 298 | | | , End of Stave message proce | 233111g | | 00BB | 299 | Goldle: | | | | | 00BB 21AE | 300 | AJMP | Dismiss | | | | | 301 | | | | | | | 302 | | | | | | | 303 | | | | | | | 304 | | | | | | | 305 | ; | | | | | | 306 | ; | | | | | | 307 | | | | | | 00BD | 308 | GoMaster: | | | | | | 309 | | | | | | | 310 | | | | | | | 311 | ; Send address & | R/W~ byte | | | | | 312 | | | | | | 00BD 792B | 313 | MOV | R1,#MasBuf | ; Master buffer address | | | 00BF AA28 | 314 | MOV | R2,MASTCNT | ; # of bytes, to send or rev | | | | | | | • • • • • • • • • • • • • • • • • • • • | | AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | 4/14/1992 PAGE 7 | |----------------------------|------------|-----------------|--------------------|------------------|---------------------------------------------------------------------------| | 00C1 E526 | 315<br>316 | MOV | A,DESTAI | ORW | ; Destination address (including ; R/W~ byte). | | 00C3 200012 | 317<br>318 | JB | SUBADD, | GoMas2 | ; Branch if subaddress is needed. | | 00C6 31C5 | 319<br>320 | ACALL | XmAddr | | | | 00C8 309D03 | 320 | JNB | DRDY,GM | 12 | | | 00CB 309C02 | 322 | JNB | ARL,GM3 | | | | 00CE 2186 | 323 | GM2: | AJMP | AdTxArl | ; Arbitration loss while transmitting | | 00CL 2160 | 324 | GIVIZ. | 7131111 | / ICT / ITT | the address. | | 00D0 209F5C | 325 | GM3: | JB | RDAT, Noslave | : No Ack for address transmission. | | 00D3 20E063 | 326 | JB | ACC.0, MI | | ; Check R/W~ bit | | 00D6 211A | 327 | AJMP | MTx | ice v | , Check is it to | | 00D0 211A | 328 | AJWII | MIX | | | | | 329 | | | | ; Handling subaddress case: | | | 330 | | | | , Handing sabadacess case. | | 0000 00 | 331 | GoMas2: | NOP | | ; Subaddress needed. Address in ACC. | | 00D8 00 | | CLR | ACC.0 | | ; Force a Write bit with address. | | 00D9 C2E0 | 332 | | XmAddr | | , Porce a write bit with address. | | 00DB 31C5 | 333 | ACALL | | T.4 | | | 00DD 309D03 | 334 | JNB | DRDY,GM | | | | 00E0 309C02 | 335 | JNB | ARL,GM5 | AdTxArl | ; Arbitration loss while transmitting | | 00E3 2186 | 336 | GM4: | AJMP | | , Arbitration loss while transmitting | | | 337 | | ; the addre | 88. | | | 0005.000545 | 338 | CDAS | TD. | DD AT Maslava | ; No Ack for address transmission. | | 00E5 209F47 | 339 | GM5: | JB<br>A DECCHI | RDAT, Noslave | , NO ACK for address transmission. | | 00E8 E527 | 340 | MOV | A,DESSU | БАР | ; Transmit subaddress. | | 00EA 31CE | 341 | ACALL | XmByte | In a Francis | ; Arbitration loss (by Start or Stop) | | 00EC 309DCA | 342 | JNB | DRDY,SM | | | | 00EF 209CC7 | 343 | JB | ARL,SMs | - | ; Arbitration loss occurred.<br>; Subaddress transmission was not ack'ed. | | 00F2 209F3F | 344 | JB | RDAT,No. | | | | 00F5 E526 | 345 | MOV | A,DESTA | | ; Reload ACC with address. | | 00F7 30E020 | 346 | JNB | ACC.0, M | | ; It's a Write, so proceed | | | 347 | | ; by sendir | ng the data. | ; Read message, needs rp. Start and add. retransmit. | | | 348 | | | | , Kead message, needs ip. Start and add. retransmit. | | 0071 750000 | 349 | MON | IOCON 4D | CDD. DVCTD | . Cand Danastad Start | | 00FA 759822 | 350 | MOV | | BCDR+BXSTR | ; Send Repeated Start. | | 00FD 309EFD | 351<br>352 | JNB | ATN,\$<br>I2CON,#E | CDP | ; Clear useless DRDY while preparing | | 0100 759820 | 353 | MOV | 12CON,#E | CDK | ; for Repeated Start. | | 0102 200EED | 353<br>354 | JNB | ATN,\$ | | ; expecting an STR. | | 0103 309EFD<br>0106 309C02 | 355 | JNB | ARL,GM6 | | , expecting an 31 K. | | | | AJMP | MArlEnd | , | ; oops – lost arbitration. | | 0109 2182 | 356 | | ACALL | XmAddr | ; Retransmit address, this time with the | | 010B 31C5 | 357<br>358 | GM6: | ACALL | AlliAddi | ; Read bit set. | | 010D 200D02 | | INID | DRDY.GN | 17 | , Read bit set. | | 010D 309D03 | 359 | JNB<br>INB | ARL,GM8 | | | | 0110 309C02 | 360 | JNB<br>GM7: | ARL,GMA<br>AJMP | | ; Arbitration loss while transmitting | | 0113 2186 | 361 | GM7: | AJMIT | AdTxArl | ; the address. | | 0115 000015 | 362 | CMO | ID | DDAT Maslavi | ; the address. ; No Ack – the slave disappeared. | | 0115 209F17 | 363 | GM8: | JB<br>MD av | RDAT, Noslave | | | 0118 801F | 364 | SJMP | MRcv | | ; Proceed receiving slave's data. | | | 365 | . A W/ | | Master transmits | the data | | | 366<br>267 | ; A Write mes | sage. | master transmits | tile tiata. | | | 367 | | | | | | PPCODE1 | 83C75 | 1 Multimaster I2C | Routines | | | 4/14/1992 | PAGE 8 | |--------------------------|------------|-------------------|-------------|---------------------|-----------------------------------------|------------------------------|---------| | 011A 00 | 368<br>369 | MTx: | NOP | | | | | | 011B E7 | 370 | MTxLoop: | MOV | A,@R1 | : Get hy | te from buffer. | | | 011C 09 | 371 | INC | R1 | 11,0111 | | e address. | | | 011D 31CE | 372 | ACALL | XmByte | | , | | | | 011F 309D97 | 373 | JNB | | MsgEnd2 | : Arbitra | tion loss (by Start or Stop) | | | 0122 209C94 | 374 | JB | ARL,SM | - | | ation loss. | | | 0125 209F0C | 375 | JВ | RDAT,No | • | , , , , , , , , , , , , , , , , , , , , | wion loss. | | | 0128 DAF1 | 376 | DJNZ | R2,MTxI | | Looni | f more bytes to send. | | | | 377 | | , - 1-,1-1 | | , Boop I | more bytes to send. | | | 012A 752422 | 378 | MOV | MSGSTA | AT,#MTXED | : Report | completion of buffer | | | | 379 | | | | ; transm | _ | | | 012D 8025 | 380 | SJMP | MTxStop | ) | , | | | | 012F 752424 | 381 | NoSlave: | MOV | MSGSTAT,#M7 | TXNOSLV | | | | 0132 8020 | 382 | SJMP | MTxStop | | | | | | 0134 752423 | 383 | NoAck: | MOV | MSGSTAT,#M7 | XNAK | | | | 0137 801B | 384 | SJMP | MTxStop | | | | | | | 385 | | | | | | | | | 386 | | | | | | | | | 387 | | | | | | | | | 388 | ; Master receive | - a Read fi | rame | | | | | | 389 | | | | | | | | 0139 31F6 | 390 | MRcv: | ACALL | ClaRcv8 | ; Receiv | e a byte. | | | 013B 8002 | 391 | SJMP | MRcv2 | | | • | | | 013D 31ED | 392 | MRcvLoop: | ACALL | AckRcv8 | | | | | 013F 309D39 | 393 | MRcv2: | JNB | DRDY,MArl | ; Other's | Start or Stop. | | | 0142 F7 | 394 | MOV | @R1,A | | ; Store r | eceived byte. | | | 0143 09 | 395 | INC | R1 | | ; Advan | ce address. | | | 0144 DAF7 | 396 | DJNZ | R2,MRcv | Loop | | | | | | 397 | | | | | | | | | 398 | ; Received the o | desired num | ber of bytes - send | l Nack. | | | | | 399 | | | | | | | | 0146 759980 | 400 | MOV | I2DAT,#8 | 30h | | | | | 0149 309EFD | 401 | JNB | ATN,\$ | | | | | | 014C 309D2C | 402 | JNB | DRDY,M | | | | | | 014F 752421 | 403 | MOV | | T,#MRCVED | | | | | 0152 8000 | 404 | SJMP | MTxStop | ) | ; Go to s | end Stop or Repeated Start | • | | | 405 | | | | | | | | | 406 | | | | | | | | | 407 | ~ | | | | | | | | 408 | ; Conclude this | | • | | | | | | 409 | ; Send Stop, or | a Repeated | Start | | | | | | 410 | | | | | | | | 0154 200105 | 411 | Marin C. | TO TO | D D (mpm) | _ | | | | 0154 300105 | 412 | MTxStop: | JNB | RPSTRT,MTxS | top2 | ; Check if Repeated Start | needed | | 0157 759822 | 413 | MOV | TOGON # | DCDD DVCDD | | ; Around if not RPSTRT. | | | 0157 739822<br>015A 8007 | 414 | MOV | | BCDR+BXSTR | | ; Send Repeated Start. | | | 015A 8007<br>015C A202 | 415 | SJMP<br>MTvStop2: | MTxStop | | | . 6 | 103 | | 015C A202<br>015E 92DE | 416<br>417 | MTxStop2: | MOV | C,SETMRQ | | ; Set new Master Request | | | OLUE 92DE | 417 | MOV | MASTR( | ي,ر | | ; by SETMRQ bit of MA | SCMD. | | 0160 759821 | 419 | MOV | I2CON # | DCDD DVCTD | | Dogwood the INV | . 041 | | 0.00 /0/021 | 420 | 1410 4 | 12CON,# | BCDR+BXSTP | | ; Request the HW to send | а этор. | | | 120 | | | | | | | | PPCODE1 | 83C75 | 1 Multimaster I2C | Routines | 4/14/1992 | PAGE | |-------------|-------|-----------------------------------------|---------------------------------|-----------------------------------------|------| | 0163 309EFD | 421 | MTxStop3: | JNB ATN,\$ | ; Wait for Attention | | | 0166 759820 | 422 | MOV | I2CON,#BCDR | ; Clear the useless DRDY, generated | | | | 423 | | | ; by SCL going high in preparation | | | | 424 | | | ; for thr Stop or Repeated Start. | | | 0169 309EFD | 425 | JNB | ATN,\$ | ; Wait for ARL, STP or STR. | | | 016C 209C13 | 426 | JB | ARL,MarlEnd | ; Lost arbitration trying to send | | | 0100 207015 | 427 | | | ; Stop or a ReStart. | | | | 428 | | | , 200 0 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | | | | 429 | · Master is don | e with this message. Ma | y proceed with new messages, if any, | | | | 430 | ; or exit. | ie with this message. | y proceed with new messages, it air, | | | | 430 | , or exit. | | | | | 0165 7110 | | ACALL | MostNovrt | ; Master Event Routine. May Prepare | | | 016F 7112 | 432 | ACALL | MastNext | | | | | 433 | | | ; the pointers and data for the | | | | 434 | | ; | next Master message. | | | | 435 | | | | | | 0171 30DE05 | 436 | JNB | MASTRQ,MMsgEnd | ; Go end service routine if MASTRQ | | | | 437 | | | ; does not indicate that the master | | | | 438 | | | ; should continue (was set according | | | | 439 | | | ; to SETMRQ bit, or by MastNext). | | | | 440 | | | | | | 0174 309B02 | 441 | JNB | STR,MMsgEnd | ; Return from the ISR, unless Start | | | | 442 | | | ; (avoid danger if we do not return: | | | | 443 | | | ; if there was a Stop, the watchdog | | | | 444 | | | ; is inactive until next Start). | | | 0177 01BD | 445 | AJMP | GoMaster | ; Loop for another Master message | | | | 446 | | ; | | | | 0179 | 447 | MMsgEnd: | | ; End of Master messages, | | | 0179 8033 | 448 | SJMP | Dismiss | | | | | 449 | | | | | | | 450 | | | | | | | 451 | | | | | | | 452 | | | | | | | 453 | : Terminate ma | astership due to an arbitration | n loss: | | | | 454 | , 1011111111111111111111111111111111111 | | | | | 017B | 455 | MArl: | | | | | 0176 | 456 | WIZEII. | | | | | 017B 309B02 | 457 | JNB | STR,MArl2 | ; If lost arbitration due to other | | | 01/6 309602 | | JIND | STK,WAII2 | | | | 017E 014D | 458 | A IMD | GoSlave | ; Master's Start, go be a slave. | | | 017E 014D | 459 | AJMP | Gostave | | | | 0100 | 460 | 14-40 | | | | | 0180 | 461 | Marl2: | <b>D</b> | | | | 0180 21AE | 462 | AJMP | Dismiss | | | | | 463 | | | | | | | 464 | | | | | | | 465 | | | | | | | 466 | | Master to Slave due to arbitr | | | | | 467 | ; transmission | of a message. The MASTR | Q bit was cleared trying to write a | | | | 468 | | | to retry transmission when the | | | | 469 | ; bus gets free | | | | | | 470 | , , , , , , , , , , , , , , , , , , , | . <b>.</b> | | | | 0182 | 471 | MArlEnd: | | | | | | 472 | SETB | MASTRQ | ; Set Master Request - which will get | | | 0182 D2DE | 472 | 3010 | MUDIK | ; into effect when we are done as a | | | | 474 | | | ; slave. | | | | | | | | | | PPCODE1 | 83C75 | l Multimaster I2C | Multimaster I2C Routines | | 4/14/1992 PAGE 10 | |--------------------|---------------|-------------------|--------------------------|-----------------------|----------------------------------------| | 0184 217B | 475<br>476 | AJMP | MArl | | | | | 477<br>478 | ; Handling arb | itration loss | while transmitting | an address | | 0186 209BF2 | 479 | AdTxArl: | JB | STR,MArl | Non gunghanana Start or Star | | 0189 209AEF | 480 | JB | STP,MA | | ; Non-synchronous Start or Stop. | | 0107 207 ILI | 481 | 10 | 311,MA | | | | | 482 | : Switch from | Master to SI: | ave due to arbitratio | on loss while transmitting | | | 483 | | | | transmitted by the new Master. | | | 484 | | * 473 | | | | 018C B80003 | 485 | CJNE | R0,#0,Ac | TxArl2 | | | | 486 | | | | ; Arl on last bit of address | | | 487 | | | | ; (R0 is 0 on exit from XmAddr). | | 018F 14 | 488 | DEC | Α | | ; The lsb sent, in which arl occured | | | 489 | | | | ; must have been 1. By decrementing | | | 490 | | | | ; A we get the address that won. | | 0190 8012 | 491 | SJMP | AdAr3 | | | | 0100 | 492 | | | | | | 0192 | 493 | AdTxArl2: | | | | | 0192 03<br>0193 F9 | 494 | RR | A | | ; Realign partially Tx'ed ACC | | 0193 F9<br>0194 E8 | 495<br>496 | MOV<br>MOV | R1,A<br>A,R0 | | ; and save it in R1 | | 0195 9001A6 | 490 | MOV | DPTR.#MaskTable | | ; Pointer for lookup table | | 0198 93 | 498 | MOVC | A,@A+DPTR | | | | 0199 59 | 499 | ANL | A,R1 | /I IIX | ; Set address bits to be received, | | | 500 | 2 | 71,111 | | ; and the bit on which we lost | | | 501 | | | | ; arbitration to 0 | | | 502 | | | | ; Now we are ready to receive the rest | | | 503 | | | | ; of the address. | | | 504 | | | | | | | 505 | | | | | | 019A 759890 | 506<br>507 | MOV | I2CON,# | BCXA+BCARL | ; Clear flags and release the clock. | | 019D 5108 | 508 | ACALL | RBit3 | | ; Complete the address using reception | | | 509 | | | | ; subroutine. | | 019F 209D02 | 510 | JB | DRDY,A | dAr3 | ; Around if received address OK | | 01A2 01B3 | 511 | AJMP | SMsgEnd | i | ; Unexpected Start or Stop - end | | 01 4 4 04 7 7 | 512 | | | | ; as a slave. | | 01A4 0155 | 513 | AdAr3: | AJMP | STstRW | ; Proceed to check the address | | | 514 | | | | ; as a slave. | | 01A6 FF7E3E1 | 515<br>IE 516 | MookTokla | DD | 000 751 251 15 | CI OFI OCI 001 001 002 1 | | 01AA 0E06020 | | MaskTable: | DB | Offn,/En,3En,1E | Eh,0Eh,06h,02h,00h, ; 0ffh is dummy | | OTAN OLOGOZ | 517 | | | | | | | 518 | ; End I2C Inter | runt Service | Routine: | | | | 519 | , End ize inter | Tupt bet vice | Routine. | | | 01AE 711E | 520 | Dismiss: | ACALL | I2CDONE | | | | 521 | | | | | | 01B0 7598F4 | 522 | MOV | I2CON.# | BCARL+BCSTP+ | BCDR+BCXA+BIDLE | | 01B3 C2DC | 523 | CLR | TIRUN | | | | 01B5 D0E0 | 524 | POP | ACC | | | | 01B7 FA | 525 | MOV | R2,A | | | | 01B8 D0E0 | 526 | POP | ACC | | | | | | | | | | AN430 | PPCODE1 | 83C75 | l Multimaster I2C | Routines | | | 4/14/1992 | PAGE 11 | |-------------|-------|-------------------|------------|------------------------------------------|-------------|----------------------|---------| | 01BA F9 | 527 | MOV | R1,A | | | | | | 01BB D0E0 | 528 | POP | ACC | | | | | | 01BD F8 | 529 | MOV | R0,A | | | | | | 01BE D0E0 | 530 | POP | ACC | | | | | | 01C0 D0D0 | 531 | POP | PSW | | | | | | 01C2 D2AC | 532 | SETB | EI2 | | | | | | | 533 | | | | | | | | 01C4 22 | 534 | RET | : Return | from I2C interrupt Service Rou | ıtine | | | | | 535 | | | , | | | | | | 536 | ******** | ***** | ******** | ***** | ****** | ***** | | | 537 | ; | Byte Trai | nsmit and Receive Subroutines | | | | | | 538 | ********* | • | ******** | | ****** | ***** | | | 539 | • | | en e | | | | | | 540 | | | | | | | | | 541 | | | | | | | | | 542 | | XmAddr: | : Transmit Address and R/W~ | | | | | | 543 | : | | Transmit a byte | | | | | | 544 | , | J J 1 | | | | | | 01C5 F599 | 545 | XmAddr: | MOV | I2DAT,A | · Send fi | rst bit, clears DRD | Y . | | 01C7 75981C | 546 | MOV | | BCARL+BCSTR+BCSTP | , bond n | ist on, clears BRD | •• | | 0107 707010 | 547 | 1.10 | 12001., | DOTALD (DODIN) DODIN | · Clear s | tatus, release SCL. | | | 01CA 7808 | 548 | MOV | R0,#8 | | | as bit counter | | | 01CC 8004 | 549 | SJMP | XmBit2 | | , but Ro | as bit counter | | | 01CE 7808 | 550 | XmByte: | MOV | R0.#8 | | | | | 01D0 F599 | 551 | XmBit: | MOV | I2DAT,A | · Send th | e first bit. | | | 01D2 23 | 552 | XmBit2: | RL | Α | ; Get ne | | | | 01D3 309EFD | 553 | JNB | ATN,\$ | A | | r bit sent. | | | 01D6 309D08 | 554 | JNB | DRDY,X | mRev | - | be data ready. | | | 01D9 D8F5 | 555 | DJNZ | R0,XmB | | | until all bits sent. | | | 01DB 7598A0 | 556 | MOV | | BCDR+BCXA | - | to receive mode. | | | 01DE 309EFD | 557 | JNB | ATN,\$ | BEBRIBEAR | | r acknowledge bit. | | | 0102 307210 | 558 | 31112 | 21111,φ | | ; flag cle | • | | | 01E1 22 | 559 | XmBex: | RET | | , mag cic | arcu. | | | 012122 | 560 | Timbex. | ICD I | | | | | | | 561 | • | | | | | | | | 562 | ; Byte receive re | outines | | | | | | | 563 | ; | outines. | | | | | | | 564 | ; ClsRcv8 | clears the | status register (from Start con | dition) | | | | | 565 | · | | receives a byte. | union) | | | | | 566 | ; AckRcv8 | | acknowledge, and then receive | ec a new h | ute | | | | 567 | · | | or Stop is encountered immedi | • | | | | | 568 | • | | Rcv8 returns with 7 in R0. | actly after | the | | | | 569 | ; ClaRcv8 | | transmit active state and relea | cac alaak | | | | | 570 | · | | acknowledge). | SES CIOCK | | | | | 571 | • | (Hom the | acknowledge). | | | | | | 572 | • | A contair | is the received byte upon return | | | | | | 573 | • | | ng used as a bit counter. | и. | | | | | 574 | , | NO 18 DELI | ing used as a bit counter. | | | | | | 575 | <b>;</b> | | | | | | | 01E2 75989C | 576 | ClsRcv8: | MOV | ICON #DCADI DCCTD | DCCTD . P | CVA | | | 01LL 13909C | 577 | ;Clear status reg | | I2CON,#BCARL+BCSTR+ | DC91L+B | CAA | * | | 01E5 309EFD | 578 | JNB | ATN,\$ | | | | | | 01E8 309D22 | 579 | JNB | DRDY,R | CVev | | | | | 0120 303022 | 517 | TIAD | DKD I,K | CYCA | | | | ## AN430 | PPCODE1 | 83C751 | Multimaster I2C I | Routines | | 4/14/1992 PAGE 12 | |------------------------|------------|-------------------|----------------|-------------------------------|----------------------------------------------------------------------| | 01EB 800F | 580<br>581 | SJMP | Rcv8 | | | | 01ED 759900 | 582 | AckRcv8: | MOV | I2DAT,#0 | ; Send Ack (low) | | 01F0 309EFD | 583 | JNB | ATN,\$ | 123711,110 | , bend field (10 m) | | 01F3 309D18 | 584 | JNB | DRDY.RC | Verr | ; Bus exception – exit. | | 01F6 7598A0 | 585 | ClaRcv8: | MOV | I2CON,#BCDR+BCXA | ; clear status, release clock | | 01F0 /396A0 | 586 | | | 12CON,#BCDK+BCAA | ;from writing the Ack. | | 01F9 309EFD | 587<br>588 | JNB | ATN,\$ | | | | 01FC 7807 | 589 | Rcv8: | MOV | R0,#7 | ; Set bit counter for the first seven | | | 590 | | | | ; bits. | | 01FE E4 | 591 | CLR | Α | | ; Init received byte to 0. | | 01FF 4599 | 592 | RBit: | ORL | A,I2DAT | ; Get bit, clear ATN. | | 0201 23 | 593 | RBit2: | RL | A sist was a second | ; Shift data. | | 0202 309EFD | 594 | JNB | ATN,\$ | | ; Wait for next bit. | | 0205 309D05 | 595 | JNB | DRDY,RC | CVex | ; Exit if not a data bit (could be Start/ | | | 596 | | | | ; Stop, or bus/protocol error) | | 0208 D8F5 | 597 | RBit3: | DJNZ | R0.RBit | ; Repeat until 7 bits are in. | | 020A A29F | 598 | MOV | C,RDAT | 110,11211 | ; Get last bit, don't clear ATN. | | 020C 33 | 599 | RLC | A A | | ; Form full data byte. | | 020D 22 | 600 | RCVex: | RET | | , I offit full data byte. | | 020D 22 | 601 | KC vex. | KEI | | | | 020E 7809 | 602 | RCVerr: | MOV | R0,#9 | ; Return non legitimate bit count | | 0210 22 | 603 | RET | | · | | | | 604 | | | | | | | 605 | | | | | | | 606 | ******** | ***** | ******* | ********* | | | 607 | • | | terrupt Service Routine | | | | 608 | , | I2C us Tir | • | | | | 609 | , ********* | | | *********** | | | 610 | , | | | | | | 611 | . In addition to | concerting the | e timeout in MSGSTAT, we u | undata a failura | | | | | | llows different types of time | | | | 612 | | | mows different types of time | out handing by the | | | 613 | ; main program | • | | | | 0011 0000 | 614 | my an | CV D | ) ( A GEED O | W. f | | 0211 C2DE | 615 | TIISR: | CLR | MASTRQ | ; "Manual" reset. | | 0213 759801 | 616 | MOV | I2CON,#I | | · · · · · · · · · · · · · · · · · · · | | 0216 7598BC | 617 | MOV | I2CON,#1 | BCXA+BCDR+BCARL+BC | CSTR+BCSTP | | | 618 | | | | | | 0219 752430 | 619 | TI1: | MOV | MSGSTAT,#TIMOUT | ; Status Flag for Main. | | 021C 74FF | 620 | TI2: | MOV | A,#0FFh | | | 021E B52902 | 621 | CJNE | A,TITOC | NT,TI3 | ; Increment TITOCNT, saturating | | 0221 8002 | 622 | SJMP | TI4 | | ; at FFh. | | 0223 0529 | 623 | TI3: | INC | TITOCNT | | | | 624 | | | | | | 0225 5130 | 625 | TI4: | ACALL | RECOVER | | | | 626 | | | | | | 0227 D2DD | 627 | SETB | CLRTI | | ; Clear TI interrupt flag. | | 0227 B2BB<br>0229 114C | 628 | ACALL | XRETI | | ; Clear interrupt pending flag (in | | 0229 1170 | 629 | ACALL | ARLII | | ; order to re–enable interrupts). | | 0220 052 4 01 | | MOV | CD Ctool-C | Sova. | ; Realign stack pointer, re-doing | | 022B 852A81 | 630 | MOV | SP,StackS | Dave | ; Realign stack pointer, re—doing<br>; possible stack changes during | | | 631 | | | | 71 | | | 632 | | | | ; the I2C interrupt service routine. | | | | | | | | AN430 | PPCODE1 | 83C75 | 1 Multimaster I2C | Routines | | 4/14/199 | PAGE 13 | |------------------------|---------|-------------------|-------------|------------------------------|--------------------------|--------------------------| | | 633 | | ; TimerI is | nterrupts in other ISR's | | | | | 634 | | ; were not | allowed! | | | | 022E 21AE | 635 | AJMP | Dismiss | ; Go back to the I2C service | ce routine, | | | | 636 | | ; in order | to return to the (main) | | | | | 637 | | ; program | interrupted. | | | | | 638 | | | | | | | | 639 | | | | | | | | 640 | ******** | ****** | ******** | ****** | ***** | | | 641 | ; | Bus recov | ery attempt subroutine | | | | | 642 | ;****** | | ********* | ****** | ***** | | | 643 | | | | | | | 0230 C2AF | 644 | RECOVER: | CLR | EA | | | | 0232 C2DE | 645 | CLR | MASTRQ | | ; "Manual" reset. | | | 0234 7598FC | 646 | MOV | - | CXA+BIDLE+BCDR+BCA | | | | 0237 C2DF | 647 | CLR | SLAVEN | | ; Non I2C TimerI n | | | 0239 D2DC | 648 | SETB | TIRUN | | ; Fire up TimerI. W | | | | 649 | | | | | erface hardware reset. | | 023B 79FF | 650 | MOV | R1,#0ffh | | , will cause ize into | criace natuwate teset. | | 023D 00 | 651 | DLY5: | NOP | | | | | 023E 00 | 652 | NOP | 1,01 | | | | | 023F 00 | 653 | NOP | | | | | | 0240 D9FB | 654 | DJNZ | R1,DLY5 | | | | | 0242 C2DC | 655 | CLR | TIRUN | | | | | 0244 D2DD | 656 | SETB | CLRTI | | | | | 0211 0200 | 657 | SEID | CLKII | | | | | 0246 D280 | 658 | SETB | SCL | | . Inner als also to 1: 1 | | | 0248 D281 | 659 | SETB | SDA | | ; issue clocks to nei | p release other devices. | | 024A 7908 | 660 | MOV | R1,#08h | | | | | 024C C280 | 661 | RC7: | CLR | SCL | | | | 024E 00000000 | 662 | DB | 0,0,0,0,0 | SCL | | | | 0252 00 | 002 | DB | 0,0,0,0,0 | | | | | 0252 00<br>0253 D280 | 663 | SETB | SCL | | | | | 0255 00000000 | 664 | DB | | | | | | 0259 00 | 004 | υв | 0,0,0,0,0 | | | | | 025A D9F0 | 665 | DJNZ | D1 DC7 | | | | | 025C C280 | 666 | CLR | R1,RC7 | | | | | 025E 0000 | 667 | DB | SCL | | | | | 025E 0000<br>0260 C281 | 668 | | 0,0 | | | | | 0260 C281 | | CLR | SDA | | | | | | 669 | DB | 0,0 | | | | | 0264 D280 | 670 | SETB | SCL | | | | | 0266 00000000 | 671 | DB | 0,0,0,0,0 | | | | | 026A 00 | <b></b> | | : | | | | | 026B D281 | 672 | SETB | SDA | | | | | 026D 00000000 | 673 | DB | 0,0,0,0,0 | | ; Issue a Stop. | | | 0271 00 | | | | | | | | | 674 | | | | | | | 0272 7598BC | 675 | Rex: | MOV | I2CON,#BCXA+BCDR+B | CARL+BCSTR+BCS | TP; clear flags | | 0275 D2AF | 676 | SETB | EA | | | - | | 0277 22 | 677 | RET | | | | | | | 678 | | | | | | | PPCODE1 | 83C751 | Multimaster I2C | Routines | | | 4/14/1992 | PAGE 14 | |-------------|--------|---------------------|--------------|-------------|---------------------------------|--------------------|---------| | | 679 | ********* | ****** | ***** | ******* | ****** | ***** | | | 680 | ; | | | | | | | | 681 | ; | Main Prog | ram | | | | | | 682 | | | | | | | | | 683 | ******** | ***** | ***** | ******* | ****** | ***** | | | 684 | | | | | | | | | 685 | : Message ping | oong game. | Each mess | age is transmitted by | | | | | 686 | | | | bus, and it contains o | ne hyte | | | | 687 | | | | data byte as a slave in | • | | | | 688 | | | | as a master. The data re | | | | | 689 | | | | ne data formerly sent, u | | | | | 690 | ; it is a "reset" v | | | | | | | | 691 | | | | e similar code, where the | ne node | | | | 692 | | | | destination address of | | | | | 693 | ; one, and vice v | | | | | | | | 694 | | | cessor trie | es to send is 00h. One of | of the | | | | 695 | | | | and the second processo | | | | | 696 | | | | ttempt to confirm it ag | | | | | 697 | | | | ent and transmit it. Sul | | | | | 698 | | | | the expected value, unt | • | | | | 699 | | | _ | vely reset by the 00h re | | | | | 700 | ; the next incren | | | | | | | | 701 | ; A toggling out | put (TogLEI | ) tells the | outer world that the "p | oing pong" | | | | 702 | | | | ed happens we tempor | | | | | 703 | ; another output, | | | | | | | | 704 | | | ode are pe | rformed in a combinati | on of main- | | | | 705 | | | | d from the I2C interrup | | | | | 706 | ; routine. | | | | | | | | 707 | | | | | | | | | 708 | | | | | | | | | 709 | ; Initial set-ups: | | | | | | | | 710 | ; Load CT1,CT0 | bits of I2Cl | FG register | r, according to the clock | k | | | | 711 | ; crystal used. | | | | | | | | 712 | ; Load RAM loc | ation MYAI | DDR with | the I2C address of this | processor. | | | | 713 | | | | le locations (R_CTVAI | | | | | 714 | | | | <immediate> command</immediate> | | | | | 715 | | | | | | | | 0278 758107 | 716 | Reset: | MOV | SP,#07h | ;Set stack location. | | | | 027B E4 | 717 | CLR | Α | | | | | | 027C 90032D | 718 | MOV | DPTR,#R_ | _CTVAL | | | | | 027F 93 | 719 | MOVC | A,@A+DI | TR | | | | | 0280 F5D8 | 720 | MOV | I2CFG,A | | ; Load CT1,CT0 (I2C | timing, crystal | | | | 721 | | | | ; dependent). | | | | 0282 E4 | 722 | CLR | Α | | | | | | 0283 90032C | 723 | MOV | DPTR,#R_ | MYADDI | 3 | | | | 0286 93 | 724 | MOVC | A,@A+DF | TR | ; Get this node's addre | ess from ROM table | | | 0287 F525 | 725 | MOV | MYADDR | ,A | ; into MYADDR RAN | I location. | | | | 726 | | | | | | | | 0289 C293 | 727 | CLR | OnLED | | | | | | | 728 | | | | | | | | | 729 | | | | | | | | 028B C291 | 730 | Reset2: | CLR | ErrLED | ; Flash LED. | | | | 028D 51E6 | 731 | ACALL | LDELAY | | | | | | | | | | | | | | AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | | | 4/14/1992 | PAGE 15 | |-------------|------------|-------------------|--------------|-----------------------------------------|------------|-------------------------|----------------|---------| | 028F D291 | 732 | SETB | ErrLED | | | | | | | 0291 C209 | 733 | CLR | SErrFLAG | 7 | | | | | | 0293 C208 | 734 | CLR | TRQFLA | | | | | | | | | | | | | | | | | 0295 753750 | 735 | MOV | FAILCNT | ,#3011 | | | | | | 0298 D290 | 736 | SETB | TogLED | | | • | | | | 029A 753850 | 737 | MOV | TOGCNT | ,#050h | ; Initiali | ze pin-toggling cou | nter | | | | 738 | | | | | | | | | | 739 | ; Enable slave of | - | | 100 | | | | | | 740 | ; The Idle bit is | | | | | | | | | 741 | | | | - | on power_up reset. | | | | 029D 759840 | 742 | MOV | I2CON,#I | BIDLE | | will idle till next Sta | rt. | | | 02A0 D2DF | 743 | SETB | SLAVEN | | ; Enable | slave operation. | | | | | 744 | | | | | | | | | | 745 | ; Enable interru | | | | | | | | | 746 | ; This is necessa | ary for both | Slave and l | Master or | perations. | | | | 02A2 D2AB | 747 | SETB | ETI | | ; Enable | timer I interrupts. | | | | 02A4 D2AC | 748 | SETB | EI2 | | ; Enable | I2C port interrupts | | | | 02A6 D2AF | 749 | SETB | EA | | ; Enable | global interrupts. | | | | | 750 | | | | | | | | | | 751 | ; Set up Master | operation. | | | | | | | | 752 | • | • | | | | | | | 02A8 752000 | 753 | MOV | MASCMI | D,#0h | ; "Regu | lar" master transmis | sions. | | | 02AB 90032E | 754 | MOV | | ongADDR | | | | | | 02AE E4 | 755 | CLR | Α | | | | | | | 02AF 93 | 756 | MOVC | A,@A+D | PTR | | | | | | 02B0 F526 | 757 | MOV | DESTAD | | . The na | artner address. The L | SR is | | | 02501520 | 758 | | 2201112 | , | • | or a Write transaction | | | | 02B2 752801 | 759 | MOV | MASTCN | JT#01h | | ge length – a single | | | | 02B2 732001 | 760 | MOV | MINDICI | (1,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | , 1410334 | ge length – a single | byte. | | | 02B5 | 761 | PPSTART: | | | | | | | | 02B5 752B00 | 762 | MOV | MasBuf,# | 00h | | | | | | 0203 732000 | 763 | WIOV | MasDu1,π | OOH | | | | | | | 764 | · "Dina" transm | inciant | | | | | | | | 765 | ; "Ping" transm | 1881011. | | | | | | | 0200 | | DDA. | | | | | | | | 02B8 | 766<br>767 | PP2: | TROPLA | ~ | | | | | | 02B8 D208 | 767 | SETB | TRQFLA | | | | | | | 02BA D2DE | 768 | SETB | MASTRO | 2 | | | | | | 02BC 79FF | 769 | MOV | R1,#0ffh | | | | | | | 02BE 300809 | 770 | PP22: | JNB | TRQFLA | AG,PP3 | ; Transmitted OK | | | | 02C1 D9FB | 771 | DJNZ | R1,PP22 | | | | | | | 02C3 D537F2 | 772 | MFAIL1: | DJNZ | FAILCN | T,PP2 | | | | | 02C6 5130 | 773 | ACALL | RECOVE | R | | | | | | 02C8 80C1 | 774 | SJMP | Reset2 | | | | | | | | 775 | | | | | | | | | | 776 | ; "Pong" recept | ion: | | | | | | | | 777 | | | | | | | | | 02CA 78FF | 778 | PP3: | MOV | R0,#0ffh | | ; Software timeou | t loop count. | | | 02CC 79FF | 779 | PP31: | MOV | R1,#0ffh | | | | | | 02CE 2008E7 | 780 | PP32: | JB | TRQFLA | AG,PP2 | ; Rcvd ok as slave | , go transmit. | | | 02D1 200908 | 781 | JB | SErrFLAG | G,PP5 | | | | | | 02D4 D9F8 | 782 | DJNZ | R1,PP32 | | | | | | | 02D6 D8F4 | 783 | DJNZ | R0,PP31 | | | | | | | 02D8 5130 | 784 | PPTO: | ACALL | RECOV | ER | ; Software timeou | t. | | | | | | | | | | | | AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | | 4/14/1992 | PAGE 16 | |-------------|------------|-----------------|----------------|--------------|---------------------------|---------------------------|---------| | 02DA 418B | 785<br>786 | AJMP | Reset2 | | | | | | 02DC C291 | 787 | PP5: | CLR | Erri ED | ; Receive error. | | | | 02DE 51E6 | 788 | ACALL | LDELAY | | , Receive elloi. | | | | 02E0 D291 | 789 | SETB | EnLED | | | | | | 02E2 C209 | 790 | CLR | SErrFLA | G | | | | | 02E4 41B5 | 791 | AJMP | PPSTART | | | | | | 02E4 41B3 | 792 | 7131111 | HUMAN | • | | | | | 02E6 7A30 | 793 | LDELAY: | MOV | R2,#030 | h | | | | 02E8 79FF | 794 | LDELAY1: | MOV | R1,#0ffl | | | | | 02EA D9FE | 795 | DJNZ | R1,\$ | 1(1,110111 | | | | | 02EC DAFA | 796 | DJNZ | R2,LDEL | AY1 | | | | | 02EE 22 | 797 | RET | K2,EBBE | | | | | | | 798 | , ALD I | | | | | | | | 799 | ******** | ****** | ***** | ****** | ******* | ***** | | | 800 | • | | | ent Routines. | 는 그 사용적으로 기계하는 것이다.<br>기계 | | | | 801 | ****** | | | ************* | ****** | ***** | | | 802 | , | | | | | | | | 803 | | | | | | | | | 804 | ;Invoked upon | completion of | of a messas | re transaction | | | | | 805 | _ | | | gram actually dealing | | | | | 806 | | | | C bus, by responding to | | | | | 807 | | | | e next transaction. | | | | | 808 | | | | | | | | | 809 | | | | | | | | | 810 | ; Slave Event I | Routines | | | | | | | 811 | ; | | | | | | | | 812 | ; These routine | s are invoked | d by the I20 | C interrupt service routi | ne when a | | | | 813 | | | | en completed. Our "app | | | | | 814 | | | | e with the routine SRC | | | | | 815 | | | | ption are treated the sar | ne way as | | | | 816 | ; erroneous dat | a reception in | n the "ping | pong" game. | | | | | 817 | | | | | | | | | 818 | ;SRcvdR | | | | | | | | 819 | ;Invoked when | a new messa | age has bee | n received as a Slave. | | | | | 820 | | | | | | | | 02EF 00 | 821 | SRcvdR: | NOP | | | | | | 02F0 E52F | 822 | MOV | A,SRcvB | uf | | | | | 02F2 7005 | 823 | JNZ | SR2 | | | | | | 02F4 752B01 | 824 | MOV | MasBuf,# | 01h | ; It was ping-pong res | et value | | | 02F7 800F | 825 | SJMP | SR3 | | | | | | 0000 0000 | 826 | | | | | | | | 02F9 052B | 827 | SR2: | INC | | ; The expected data. | | | | 02FB B52B0F | 828 | CJNE | A,MasBu | f,ErrSR | | | | | 02FE 052B | 829 | INC | MasBuf | | ; Data for next transm | | | | | 830 | | | | ; received incremented | l by 1. | | | | 831 | | | | | | | | | 832 | | - | - | Let the outside world | • | | | | 833 | | | _ | We actually toggle on | <b>y</b> | | | | 834<br>835 | | | | completed, in order to | | | | | 835<br>836 | slow down the | changes for | a good vis | uai indication. | | | | | 030 | | | | | | | ## AN430 | PPCODE1 | 83C751 | Multimaster I2C | Routines | | 4/14/1992 | PAGE 17 | |-------------------|------------|------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------| | 0300 D53805 | 837 | DJNZ | TOGCNT,SR3 | | | | | 0303 B290 | 838 | CPL | TogLED | ; Toggle output | | | | 0305 753850 | 839 | MOV | TOGCNT,#050h | | | | | | 840 | | | | | | | 0308 C209 | 841 | SR3: | CLR SErrFI | LAG | | | | 030A D208 | 842 | SETB | TRQFLAG | ; Request main to transmit | | | | 030C 22 | 843 | RET | | | | | | | 844 | | | | | | | 030D D209 | 845 | ErrSR: | SETB SErrFl | LAG | | | | 030F 22 | 846 | RET | | | | | | | 847 | | | | | | | | 848 | | | | | | | | 849 | ;SLnRcvdR | | | | | | • | 850 | ;Invoked when | a message received a | s a Slave is too long | | | | | 851 | ;for the receive | buffer. | | | | | | 852 | | | | | | | | 853 | ;STXedR | | | | | | | 854 | ;Invoked when | a Slave completed tr | ansmission of its buffer. | | | | | 855 | ;We do not expe | ect to get here, since | we do not plan to have | | | | | 856 | ;in our system a | master that will requ | uest data from this node. | | | | | 857 | ; | | | | | | | 858 | | | | | | | | 859 | ;SRErrR | | | | | | | 860 | ;Slave error eve | | | | | | | 861 | == | ations it will not be u | sed. | | | | | 862 | ; | | | | | | | 863 | ar n 15 | | | | | | 0310 | 864 | SLnRcvdR: | | | | | | 0310 | 865 | STXedR: | D. (D. (D. (D. (D. (D. (D. (D. (D. (D. ( | | | | | 0310 80FB | 866 | SRErrR: | JMP ErrSR | | | | | | 867 | | | | | | | | 868 | | | | | | | | 869 | ;<br>:MostNovt M | aster Event Routine. | | | | | | 870<br>871 | ; Masinext – M | aster Event Routine. | | | | | | 872 | ·Invoked when | a Macter transaction | is completed, or terminated | | | | | 873 | | e to lack of acknowle | and the second s | | | | | 874 | , willingly du | e to lack of acknowle | sage by a slave. | | | | | 875 | • | | | | | | 0312 | 876 | MastNext: | | | | | | 0312<br>0312 E524 | 877 | MOV | A,MSGSTAT | | | | | 0314 B42206 | 878 | CJNE | A,#MTXED,MN1 | L | | | | 0317 753750 | 879 | MOV | FAILCNT,#50h | | | | | 031A C208 | 880 | CLR | TROFLAG | | | | | 031C 22 | 881 | RET | | | | | | 031D | 882 | MN1: | | | | | | 031D 22 | 883 | RET | | | | | | | 884 | | | | | | | | 885 | ;I2CDONE | | | | | | | 886 | | ompletion of the I2C | interrupt service routine. | | | | | 887 | ;In this exampl | e it monitors exception | ons, and invokes the bus | | | | | 888 | recovery routi | ne when too many oo | ccurred. | | | | | 889 | | | | | | | | | | | | | | AN430 | PPCODE1 | 83C75 | 1 Multimaster I2C | Routines | | | | 4/14/1992 | PAGE 18 | |-------------|-------|-------------------|--------------|---------------|----------------------|--------------|-----------|---------| | 031E | 890 | I2CDONE: | | | | | | | | 031E E524 | 891 | MOV | A.MSG | STAT | | | | | | 0320 B43208 | 892 | CJNE | | STR,I2CD | 1 | | | | | 0323 D53705 | 893 | DJNZ | | T,I2CD1 | • | | | | | 0326 753701 | 894 | MOV | FAILCN | | ; Too many "illeg | oal" i2c int | errunts | | | 0329 C2AC | 895 | CLR | EI2 | | ; – shut off. | 5ur 120 1110 | cirapts | | | 032B 22 | 896 | I2CD1: | RET | | , 51141 5111 | | | | | | 897 | | | | | | | | | | 898 | | | | | | | | | | 899 | :******** | ***** | ***** | ****** | ***** | ***** | ***** | | | 900 | • | I2C Cor | nmunication | ns Table: | | | | | | 901 | ******** | ****** | ****** | ****** | ****** | ****** | ***** | | | 902 | | | | | | | | | | 903 | | | | | | | | | | 904 | | | | | | | | | | 905 | ; We used table | driven val | ues for clari | ty. one may use im | mediate to | load | | | | 906 | ; these values a | | | • | | | | | | 907 | | | | | | | | | | 908 | ; Contents is us | ed in the b | eginning of | the main program | to load | | | | | 909 | ; RAM location | MYADDI | R and the I2 | CFG register. | | | | | | 910 | ; The node add | ress, in R_l | MYADDR, | is application speci | ific, and un | ique for | | | | 911 | ; each device in | the I2C no | etwork. | | | | | | | 912 | ; R_CTVAL de | pends on th | he crystal cl | ock frequency. | | | | | | 913 | | | | | | | | | 032C 4E | 914 | R_MYADDR: | DB | 4Eh | ; This node's add | iress | | | | | 915 | | | | | | | | | 032D 02 | 916 | R_CTVAL: | DB | 02h | ; CT1, CT0 bit v | alues | | | | | 917 | | | | | | | | | | 918 | ,******** | ***** | ****** | ***** | ****** | ***** | ***** | | | 919 | ; | | tion Code D | | | | | | | 920 | ;******** | ****** | ***** | ****** | ****** | ***** | ***** | | | 921 | | | | | | | | | 032E 4A | 922 | PongADDR: | DB | 4Ah | ; The address of | the "partne | er" in | | | | 923 | | | | ; the ping-pong | game. | | | | | 924 | | | | | | | | | | 925 | | | | | | | | | | 926 | | | | | | | | | | 927 | | | | | | | | | | 928 | END | | | | | 1 | | | | 929 | IV COMPLETE | | | | | | | VERSION 1.2h ASSEMBLY COMPLETE, 0 ERRORS FOUND AN430 PAGE 19 | PPCODE1 83C751 Multimaster I2C I | Routines | 4/14/1992 | | |----------------------------------|----------------|------------|--| | ACC D ADDR | 00E0H | PREDEFINED | | | ACKRCV8 C ADDR | 01EDH | | | | ADAR3 C ADDR | 01A4H | | | | ADDRRCV C ADDR | 0050H | NOT USED | | | ADTXARL | 0186H | | | | ADTXARL2 C ADDR | 0192H | | | | APPFLAGS D ADDR | 0021H | | | | ARL B ADDR | 009CH | PREDEFINED | | | ATN B ADDR | 009EH | PREDEFINED | | | BCARL NUMB | 0010H | | | | BCDR NUMB | 0020H | | | | BCSTP NUMB | 0004H | | | | BCSTR NUMB | H8000 | | | | BCXA NUMB | 0080H | | | | BIDLE NUMB | 0040H | | | | BMRQ NUMB | 0040H | NOT USED | | | BTIR NUMB | 0010H | NOT USED | | | BXSTP NUMB | 0001H | | | | BXSTR NUMB | 0002H | | | | CLARCV8 C ADDR | 01F6H | | | | CLRTI B ADDR | 00DDH | PREDEFINED | | | CLSRCV8 C ADDR | 01E2H | | | | DESSUBAD D ADDR | 0027H | | | | DESTADRW D ADDR | 0026H | | | | DISMISS | 01AEH | | | | DLY5 C ADDR | 023DH | | | | DRDY B ADDR | 009DH | PREDEFINED | | | EA B ADDR | 00AFH | PREDEFINED | | | EI2 B ADDR | 00ACH | PREDEFINED | | | ERRLED B ADDR | 0091H | | | | ERRSR C ADDR | 030DH | DECEMEN | | | ETI B ADDR FAILCNT | 00ABH<br>0037H | PREDEFINED | | | GM2 C ADDR | 0057H<br>00CEH | | | | GM3 C ADDR | 00D0H | | | | GM4 C ADDR | 00E3H | | | | GM5 C ADDR | 00E5H | | | | GM6 C ADDR | 010BH | | | | GM7 C ADDR | 010BH | | | | GM8 C ADDR | 0115H | | | | GOIDLE | 00BBH | | | | GOMAS2 | 00DBH | | | | GOMASTER C ADDR | 00BDH | | | | GOSLAVE C ADDR | 004DH | | | | I2CD1 | 032BH | | | | TECHNOLIN | 001511 | | | 1992 Jun 26 136 I2CDONE. . . . . . . . . . . . . . . . . C ADDR 031EH AN430 | PPCODE1 | 83C751 Multimaster I2C I | Routines | | 4/14/1992 | PAGE 20 | |-----------|--------------------------|-----------------|------------|-----------|---------| | I2CFG | D ADDR | 00D8H | PREDEFINED | | | | I2CISR | C ADDR | 0023H | NOT USED | | | | I2CON | D ADDR | 0098H | PREDEFINED | | | | I2DAT | D ADDR | 0099H | PREDEFINED | | | | | C ADDR | 02E6H | | | | | | C ADDR | 02E8H | | | | | | C ADDR | 017BH | | | | | | C ADDR | 0180H | | | | | | C ADDR | 0182H | | | | | | D ADDR | 002BH | | | | | | D ADDR | 0020H | | | | | MASKTABLE | | 002011<br>01A6H | | | | | | D ADDR | 0028H | | | | | | B ADDR | | DDEDEEINED | | | | | | 0099H | PREDEFINED | | | | | C ADDR | 0312H | DDEDEELNED | | | | = | B ADDR | 00DEH | PREDEFINED | | | | | C ADDR | 02C3H | NOT USED | | | | | NUMB | 0020H | | | | | | C ADDR | 0179H | | | | | | C ADDR | 031DH | | | | | | C ADDR | 0139H | | | | | | C ADDR | 013FH | | | | | | NUMB | 0021H | | | | | | C ADDR | 013DH | | | | | | D ADDR | 0024H | | | | | MTX | C ADDR | 011AH | | | | | MTXED | NUMB | 0022H | | | | | MTXLOOP | C ADDR | 011 <b>BH</b> | | | | | MTXNAK | NUMB | 0023H | | | | | MTXNOSLV | NUMB | 0024H | | | | | MTXSTOP | C ADDR | 0154H | | | | | MTXSTOP2 | C ADDR | 015CH | | | | | MTXSTOP3 | C ADDR | 0163H | | | | | MYADDR | D ADDR | 0025H | | | | | NOACK | C ADDR | 0134H | | | | | NOGO | C ADDR | 0047H | | | | | NOSLAVE | C ADDR | 012FH | | | | | NOTSTR | NUMB | 0032H | | | | | ONLED | B ADDR | 0093H | | | | | P1 | D ADDR | 0090H | PREDEFINED | | | | | C ADDR | 032EH | | | | | | C ADDR | 02B8H | | | | | | C ADDR | 02BEH | | | | | | C ADDR | 02CAH | | | | | | C ADDR | 02CCH | | | | | | C ADDR | 02CEH | | | | | | | | | | | # Using the 8XC751/752 in multimaster I<sup>2</sup>C applications AN430 | PPCODE1 | 83C751 Multimaster I2C | Routines | | 4/14/1992 | PAGE 21 | |-----------|------------------------------|----------------|------------|-----------|---------| | PP5 | C ADDR | 02DCH | | | | | | C ADDR | 02B5H | | | | | | C ADDR | 02D8H | NOT USED | | | | PSW | D ADDR | 00D0H | PREDEFINED | | | | RBIT | C ADDR | 01FFH | | | | | RBIT2 | C ADDR | 0201H | NOT USED | | | | RBIT3 | C ADDR | 0208H | | | | | RBUFLEN | NUMB | 0004H | | | | | RC7 | $\dots \dots \dots C \ ADDR$ | 024CH | | | | | RCV8 | C ADDR | 01FCH | | | | | | C ADDR | 020EH | | | | | | C ADDR | 020DH | | | | | | B ADDR | 009FH | PREDEFINED | | | | | C ADDR | 0230H | | | | | | C ADDR | 0278H | | | | | | C ADDR | 028BH | | | | | | C ADDR | 0272H | NOT USED | | | | | B ADDR | 0001H | | | | | | C ADDR | 032DH | | | | | | C ADDR | 032CH | | | | | | B ADDR | 0080Н | PREDEFINED | | | | | B ADDR | 0081H | PREDEFINED | | | | | B ADDR | 0009H | | | | | | B ADDR | 0002H | | | | | | NUMB | 0010H | DDEDEENED | | | | | B ADDR | 00DFH | PREDEFINED | | | | | C ADDR | 0310H | | | | | | C ADDR | 0084H | | | | | | C ADDR | 00B3H<br>00B9H | | | | | | D ADDR | 00В9Н<br>0081Н | PREDEFINED | | | | | C ADDR | 02F9H | IKEDEITIED | | | | | C ADDR | 0308H | | | | | | C ADDR | 005DH | NOT USED | | | | | C ADDR | 0068H | 1.01 0525 | | | | | D ADDR | 002FH | | | | | SRCVD | NUMB | 0011H | | | | | SRCVDR | C ADDR | 02EFH | | | | | SRCVEND | C ADDR | 0076H | | | | | SRCVERR | C ADDR | 00A7H | | | | | SRCVSTO | C ADDR | 0066H | | | | | SRERR | NUMB | 0014H | | | | | SRERRR | C ADDR | 0310H | | | | | SRLNG | NUMB | 0012H | | | | | STACKSAVE | D ADDR | 002AH | | | | | STP | B ADDR | 009AH | PREDEFINED | | | AN430 | PPCODE1 83C751 Multimaster I2C I | Routines | | 4/14/1992 PAGE 22 | |----------------------------------|----------|------------|-------------------| | STR B ADDR | 009BH | PREDEFINED | | | STSTRW C ADDR | 0055H | | | | STX2 C ADDR | 0085H | NOT USED | | | STXBUF D ADDR | 0033H | | | | STXED NUMB | 0013H | | | | STXEDR C ADDR | 0310H | | | | STXERR | 00AEH | NOT USED | | | STXLP C ADDR | 0093H | | | | SUBADD B ADDR | 0000H | | | | TI1 C ADDR | 0219H | NOT USED | | | TI2 | 021CH | NOT USED | | | TI3 | 0223H | | | | TI4 C ADDR | 0225H | | | | TIISR C ADDR | 0211H | | | | TIMERI C ADDR | 001BH | NOT USED | | | TIRUN B ADDR | 00DCH | PREDEFINED | | | TITOCNT D ADDR | 0029H | | | | TOGCNT D ADDR | 0038H | | | | TOGLED B ADDR | 0090H | | | | TRQFLAG B ADDR | H8000 | | | | XMADDR C ADDR | 01C5H | | | | XMBEX C ADDR | 01E1H | | | | XMBIT C ADDR | 01D0H | | | | XMBIT2 C ADDR | 01D2H | | | | XMBYTE C ADDR | 01CEH | | | | XRETI C ADDR | 004CH | | | | | | | | ## I<sup>2</sup>C slave routines for the 83C751 **AN433** ### Author: Greg Goodhue The S83C751/S87C751 Microcontroller combines in a small package the benefits of a high-performance microcontroller with on-board hardware supporting the Inter-Integrated Circuit (I<sup>2</sup>C) bus interface. The 8XC751 can be programmed both as an I<sup>2</sup>C bus master, a slave, or both. An overview of the I<sup>2</sup>C bus and description of the bus support hardware in the 8XC751 microcontrollers appears in application note AN422, "Using the 8XC751 Microcontroller as an I<sup>2</sup>C Bus Master." That application note includes a programming example, demonstrating a bus-master code. Here we show an example of programming the microcontroller as an I<sup>2</sup>C slave. The code listing demonstrates communications routines for the 8XC751 as a slave on the I<sup>2</sup>C bus. It compliments the program in AN422 which demonstrates the 8XC752 as an I<sup>2</sup>C bus master. One may demonstrate two 8XC751 devices communicating with each other on the I<sup>2</sup>C bus, using the AN422 code in one, and the program presented here in the other. The examples presented here and in AN422 allow the 751 to be either a master or a slave, but not both. Switching between master and slave roles in a multimaster environment is described in application note AN435. The software for a slave on the bus is relatively simple, as the processor plays a relatively passive role. It does not initiate bus transfers on its own, but responds to a master initiating the communications. This is true whether the slave receives or transmits data-transmission takes place only as a response to a bus master's request. The slave does not have to worry about arbitration or about devices which do not acknowledge their address. As the slave is not supposed to take control of the bus, we do not demand it to resolve bus exceptions or "hangups". If the bus becomes inactive the processor simply withdraws, not interfering with the master (or masters) on the bus which should (hopefully) try to resolve the situation. The 8XC751 has a single bit I<sup>2</sup>C hardware interface where the registers may directly affect the levels on the bus, and the software interacting with the hardware registers takes part in the protocol implementation. The hardware and the low level routines dealing with the registers are tightly coupled. We repeat here the warning from the 751 bus-master application note: one should take extra care if trying to modify these lower level routines. The service routine for the I<sup>2</sup>C slave is interrupt driven per message. This allows for master communication requests which are not synchronized with the application program running on the slave. It is possible to write simple slave application programs which will not be interrupt driven, taking care not to lose master transmissions while doing something else, but the user should be discouraged from doing so. As the slave should respond to asynchronous requests of masters on the bus, an interrupt driven service routine makes sense—and, as the code demonstrates, is simple to implement. ### **DEMONSTRATION CODE** The main program operation, intended for demonstration only, is simple. There are two data buffers, one for data reception and one for data transmission. When new data has been received from the I2C bus into the receive buffer, the program writes it into the transmit buffer. The first and second bytes of received data are also copied to Port 1 and Port 3, respectively. When a bus master requests to read data, Port 1 and Port 3 will be returned for the first two bytes of requested data, while the remaining bytes will come from the transmit buffer. This allows for simple testing of a master and slave system by having the master compare data received to data sent. This scheme also allows the 8XC751 to be used as a two-byte I2C I/O port. The program begins at address 0, where the microprocessor begins execution after a hardware reset. This location contains a jump instruction to the main program, which starts at the label Reset (towards the end of the listing). Upon reset, the program initializes the stack pointer, the I2C address of the slave processor (MyAddr) and clears the data buffers and software flags. In this program the receive and transmit buffers are each eight bytes long-the maximum number of bytes is defined by the label MaxBytes. One may easily change the program to handle longer messages by changing the value of MaxBytes and allocating more data memory to the buffers. The I<sup>2</sup>C interface is configured to operate as a slave by setting the msb of register I<sup>2</sup>CFG. This is done simultaneously with loading the appropriate value of CTVAL—bits CT0 and CT1, which are determined by the frequency of the microprocessor's crystal. The interface hardware is explicitly instructed to get into the slave idle mode by setting the appropriate bit in the I2CON register. Timer I, which operates as a "watchdog" timer detecting bus hangups, is activated and its interrupts are enabled. After the initialization, the program gets to the label MainLoop. Most of the time the program will "hang" in a wait loop at this label, simply waiting for an I<sup>2</sup>C interrupt to occur. When there is an I<sup>2</sup>C bus request there will be an interrupt, the service routine will be executed and we shall return to the MainLoop label. If the service routine receives new data, it sets a flag, DatFlag, signalling that data has been updated. This flag will allow us to leave the MainLoop label, and execute a short routine copying the updated input buffer to the output (transmit) buffer. If a new bus interrupt comes before overwriting of the old read buffer data is completed, and an undesirable "mix" of old and new data might occur. This type of situation is avoided by disabiling the I<sup>2</sup>C interrupts (clearing the IE2 bit in the Interrupt Enable Register) just before copying the data to the transmit buffer, and re-enabling the interrupts when the copy operation is completed. When the copy routine is completed the DatFlag is cleared and we jump back to MainLoop, waiting for the next interrupt to occur. If the interrupt is for data transmission the service routine will not set DatFlag, and upon return we shall remain at the MainLoop label. # THE INTERRUPT SERVICE ROUTINE The service routine is interrupt driven with respect to the start of each I2C frame. but within each frame the interaction with the hardware is based on polling. An occurrence of a Start on the bus will cause an interrupt that will initiate the service routine which starts at address 23H. After saving registers, all interrupts except the I2C interrupt itself are enabled, as we want to allow response to other interrupts during the routine. The philosophy behind this is that the I<sup>2</sup>C may be a lower priority than some other operations in the system. Since the I2C hardware will stretch the clock until the program responds, an interrupt of reasonable duration will not have a harmful effect on the data transfer. Since we intend to react to the I<sup>2</sup>C hardware by polling the ATN flag in wait loops, we do not want the expected changes on the bus to take us again to the beginning of the routine. Therefore, the El2 flag is cleared, masking further I<sup>2</sup>C interrupts even when interrupts are re-enabled (by the ACALL to a RETI instruction). At the label Slave, the routine starts receiving the address on the bus. Each new address bit is read after a software wait loop detects that the ATN flag is set by the hardware. Note that with the single bit implementation of the ## I<sup>2</sup>C slave routines for the 83C751 **AN433** I<sup>2</sup>C port on the 8XC751 the software must closely support the hardware: for example, we need to explicitly clear the Start status before we enter a wait loop for the next bit. If the software does not clear the Start flag, the hardware will stretch the low period of the clock (SCL line) on the bus—and the first address bit will simply not occur. (Such a state will not go on forever—eventually the processor will release the bus as a result of a Timer I timeout.) Reception of the eight bits of Address + R/W is completed using part of the receive byte subroutines. The address received is compared to MyAddr, the address of this specific slave. If the address is different the processor goes idle and leaves the service routine. If the message is intended for this processor (received address matches MyAddr) the Read/Write bit is tested, and the program jumps to the appropriate labels. When the R/W bit is low the master requests a Write-and this slave should receive the data written into it. When the R/W bit is high the master is requesting a Read and this slave should transmit the data (at code label Read). For "Master Write" we send an acknowledge for the address byte and proceed with receiving the data bytes, responding with an acknowledge for each and transferring them into the receive buffer. For long messages, when the buffer is full (we have received MaxByte bytes) we read from the bus one additional byte and then send a negative acknowledge, letting the master know it should stop sending us data. Then we set DatFlag to signal the mainline program that new data has been received, and jump to MsgEnd. At the MsgEnd label we wait for the next Stop or Repeated Start. On a Stop we resume the idle mode (Goldle) and return from the service routine. On a Restart the slave process starts again with reception of the new address at the label Slave. If the message is short enough so that the receive buffer is not filled up, the RcvByte subroutine (called after WrtLoop) will return due to the Stop condition, DRDY will not be set, and we shall exit the loop via label WLEx—setting the DatFlag and proceeding to MsgEnd. For "Master Read" the transmit buffer is sent on the bus byte by byte in the RdLoop, using the XmitByte subroutine. We exit the loop when all the buffer is transmitted, or the Master does not respond with an acknowledge. Note that lack of acknowledgement for slave transmission does not necessarily indicate a problem or that the receiving master is busy. This could very well be a normal operation of the protocol, which defines that a receiving master signals the transmitting slave to end its message by explicitly transmitting a negative acknowledge as a response to the last byte the master is interested in. The protocol does not include inherent means for specifying in advance the length of a requested message. ### SUBROUTINES The lower level subroutines closely interact with the hardware and the activity on the bus. The XmitByte subroutine transmits one byte and receives the acknowledge bit that comes in response. The byte receive routine, which one may use from different entry points, receives a data or an address byte, and takes care of acknowledgements. When a Start or Stop is detected the subroutine returns immediately—the calling routine is expected to check the flags to determine whether a whole byte has been received (DRDY will be set), or a Start or a Stop condition has occurred. Close inspection of RcvByte code shows that a total of nine bits are being read off the bus. The first bit does not belong to the received byte, but is the acknowledge this processor sent in response of the former byte or address. Reading the Ack bit from the I2DAT register clears the Transmit Active state and DRDY, thus releasing SCL and allowing the bus activity to proceed to the next data bit. Upon return the Ack bit is left in the Carry flag, and the actual data byte received is returned in the Ack register. Upon Timer I interrupt code execution commences at address 1BH, where there is a jump to the service routine Timerl. This interrupt is caused by the watchdog timer, as a result of an I<sup>2</sup>C bus that is "hanging" without activity in the middle of a transmission for too long a period of time. The slave simply clears the bus interface, and starts all over again at the label Reset. ## I<sup>2</sup>C slave routines for the 83C751 ``` ************************* Sample I2C Slave Routines for the 8XC751 and 8XC752 ; This program demonstrates I2C slave functions for the 8XC751 and 8XC752 ; microcontrollers. The program uses separate transmit and receive data ; buffers that are each eight bytes deep. The sample main program ; copies received data to the transmit buffer such that transmitted data can ; be read back by a bus master. Buffer addresses 0 and 1 are mapped to port 1 ; and 3 respectively, such that an I2C write will affect the port outputs, and ; an I2C read will return port pin data. The 751 will accept only eight data ; bytes in any one I2C transmission, additional bytes will not be ; acknowledged. Similarly, only eight data bytes may be read from the 751 in ; any one I2C transmission. This program does not support subaddressing for ; buffer access. ******************* $TITLE(8XC751 I2C Slave Routines) SDATE (11/23/92) $MOD752 ; Value definitions. ; CT1, CT0 bit values for I2C. CTVAL EOU 02h ; Maximum # of bytes to be sent or EOU MaxBytes received. ; Masks for I2CFG bits. EOU 10h : Mask for TIRUN bit. BTTR BMRO EOU 40h ; Mask for MASTRQ bit. ; Masks for I2CON bits. BCXA EQU ; Mask for CXA bit. ; Mask for IDLE bit. BIDLE EQU 40h 20h ; Mask for CDR bit. BCDR EOU BCARL EQU 10h ; Mask for CARL bit. ; Mask for CSTR bit. BCSTR EQU 08h ; Mask for CSTP bit. 04h BCSTP EQU 02h ; Mask for XSTR bit. EOU BXSTR BXSTP EOU 01h ; Mask for XSTP bit. ; RAM locations used by I2C routines. RcvDat DATA 10h ; I2C receive data buffer (8 bytes). addresses 10h through 17h. DATA ; I2C transmit data buffer (8 bytes). Xmt Dat 18h addresses 18h through 1Fh. Flags DATA 20h ; I2C software status flags. NoAck BIT Flags.7 ; Holds negative acknowledge flag. ; Tells whether an I2C write operation DatFlag BIT Flags.6 has occurred. BitCnt DATA 21h ; I2C bit counter. DATA 22h ; Send/receive byte counter. ByteCnt 23h ; Temporary holding register. TDAT DATA ; Holds address of THIS slave. DATA 24h MyAddr 25h ; Holds received slave address + R/W. AdrRcvd DATA AdrRcvd.0 ; Slave read/write flag. RWFlag ``` # I<sup>2</sup>C slave routines for the 83C751 AN433 ``` Begin Code **************************** ; Reset and interrupt vectors. AJMP Reset ; Reset vector at address 0. ; A timer I timeout usually indicates a 'hung' bus. ; Timer I (I2C timeout) interrupt. ORG AJMP TimerI ; I2C interrupt is used to detect a start while the slave is idle. ; I2C interrupt. PUSH ; Save status. PUSH ACC ; Save accumulator. CLR ES ; Disable I2C interrupt. ACALL ClrInt ; Re-enable interrupts. Main Transmit and Receive Routines Slave: VOM I2CON, #BCARL+BCSTP+BCSTR+BCXA; Clear start status. JNB ATN,$ ; Wait for next data bit. MOV BitCnt,#7 ; Set bit count. ACALL RcvB2 ; Get remainder of slave address. MOV AdrRcvd, A ; Save received address + R/W bit. CLR ACC.0 CJNE A, MyAddr, GoIdle ; Enter idle mode if not our address. JB RWFlag, Read ; Read or Write? MOV R0, #RcvDat ; Set up receive buffer pointer. MOV ByteCnt, #MaxBytes ; Max 4 bytes can be received. WrtLoop: ACALL SendAck ; Send acknowledge. RcvByte ACALL ; Get data byte from master. JNB DRDY, WLEx ; Must be end of frame? VOM @RO,A ; Save data. ; Advance buffer pointer. INC DJNZ ByteCnt, WrtLoop ; Back to receive if buffer not full. ACALL SendAck ; Send acknowledge. ACALL RcvByte ; Get, but do not store add'l data. VOM I2DAT,#80h ; Send negative acknowledge. JNR ATN,$ ; Wait for acknowledge sent. WLEx: SETB DatFlag ; Flag main that data has been received. SJMP MsgEnd ; Buffer full, enter idle mode. Read: MOV R0, #XmtDat ; Set up transmit buffer pointer. MOM ByteCnt, #MaxBytes ; Max bytes to be sent. ACALL SendAck ; Send address acknowledge. RdLoop: VOM A. @RO ; Get data byte from buffer. R0, #XmtDat, RdL1 ; Return port 1 value instead of buffer CJNE VOM A,P1 data if this is buffer address 0. ; RO, #XmtDat+1, RdL2 ; Return port 3 value instead of buffer RdL1: CJNE VOM A, P3 ; data if this is buffer address 1. RdL2: INC R0 ; Advance buffer pointer. ACALL XmitByte ; Send data byte. NoAck, RLEx ; Exit if NAK. DJNZ ByteCnt, RdLoop ; Back if more data requested & avail. ``` # I<sup>2</sup>C slave routines for the 83C751 # **AN433** ``` RLEx: MsgEnd ; Done, enter idle mode. SJMP MsgEnd: JNB ATN,$ ; Wait for stop or repeated start. JΒ STR, Slave ; If repeated start, go to slave mode, else enter idle mode. I2CON, #BCSTP+BCXA+BCDR+BCARL+BIDLE; Enter slave idle mode. GoIdle: MOV ACC ; Restore accumulator. POP PSW ; Restore status. SETB ES ; Re-enable I2C interrupts. RET Subroutines ; Byte transmit routine. Enter with data in ACC. XmitByte: MOV BitCnt,#8 ; Set 8 bits of data count. XmBit: MOV I2DAT, A ; Send this bit. RL ; Get next bit. JNR ATN,$ ; Wait for bit sent. BitCnt, XmBit D.TNZ ; Repeat until all bits sent. I2CON, #BCDR+BCXA ; Switch to receive mode. MOV JNB ATN.S ; Wait for acknowledge bit. Flags, I2DAT ; Save acknowledge bit. MOV RET ; Byte receive routines. SendAck : sends an I2C acknowledge. RcvByte : receives a byte of data. RcvB2 : receives a partial byte of I2C data, used to allow reception of 7 bits of slave address information. Data is returned in the ACC. MOV SendAck: I2DAT,#0 ; Send receive acknowledge. JNB ATN,$ ; Wait for acknowledge sent. RET RcvByte: MOV BitCnt,#8 ; Set bit count. RcvB2: CLR ; Init received byte to 0. RBit: A, I2DAT ORT ; Get bit, clear ATN. RL ; Shift data. Α JNB ATN, $ ; Wait for next bit. DRDY, RBEx ; Exit if not a data bit. DJNZ BitCnt, RBit ; Repeat until 7 bits are in. MOV C, RDAT ; Get last bit, don't clear ATN. RIC Α ; Form full data byte. RET RBEx: ; Timer I timeout interrupt service routine. TimerI: SETB CLRTI ; Clear timer I interrupt. MOV I2CFG,#0 ; Turn off I2C. VOM I2CON,#BCXA+BCDR+BCARL+BCSTR+BCSTP ; Reset I2C flags. ACALL ClrInt ; Clear interrupt pending flag. AJMP Reset ; Return to mainline. ClrInt: RETI ``` # I<sup>2</sup>C slave routines for the 83C751 ``` Main Program ; Set stack location. SP,#2Fh Reset: MOV ; Enable I2C interrupt. MOV IE,#90h ; Set up pointer to data area. MOV R0, #RcvDat ; Set up buffer length counter. R1,#2*MaxBytes MOV ; Clear buffer memory. RLoop: MOV @R0,#0 R0 ; Advance to next buffer position. INC ; Repeat until done. DJNZ R1, RLoop MyAddr,#40h ; Set slave address. MOV Flags,#0 ; Clear system flags. MOV I2CFG, #80h+CTVAL ; Enable slave functions. MOV I2CON, #BIDLE : Put slave into idle mode. MOV ; Enable timer I interrupts. ETI SETB SETB TIRUN ; Turn on timer I. ; This sample mainline program copies the first two received bytes to Port 1 and Port 3 whenever there is an I2C write operation. It Also copies the rest of the input buffer to the output buffer at the same time. ; Wait for data sent from I2C. MainLoop: JNB DatFlag,$ ; Turn off interrupts during data move. CLR EA MOV P1, RcvDat ; First buffer location goes to port 1. P3,RcvDat+1 ; Second buffer location goes to port 3. MOV MOV R0, #RcvDat ; Set input buffer start pointer. ; Set output buffer start pointer. MOV R1, #XmtDat MOV R2,#MaxBytes ; Set buffer length counter. ; Get data from input buffer. ML2: MOV A, @RO MOV GR1,A ; Store data in output buffer. ; Increment input buffer pointer. INC R1 ; Increment output buffer pointer. INC R0 ; Repeat until entire buffer is updated. R2,ML2 DJNZ ; Clear I2C transmission flag. DatFlag CLR EA ; Data move done, re-enable interrupts. SETB MainLoop ; Wait for next I2C transmission. SJMP END ``` 145 Philips Semiconductors Application note # Connecting a PC keyboard to the I<sup>2</sup>C-bus **AN434** # CONNECTING A PC KEYBOARD TO THE I<sup>2</sup>C BUS This application note illustrates the use of a low-cost 8-bit microcontroller—the 8XC751—to interface a standard PC/AT keyboard to the I<sup>2</sup>C bus. The 8XC751 (83C751 = ROM-version, 87C751 = EPROM-version) is ideally suited for the task thanks to its built-in I<sup>2</sup>C interface, small form-factor (24-pin DIP or 28-pin PLCC) and low power consumption (11mA typical @ 12 MHz; see Figure 1). The application software easily fits within the 2K bytes code and 64 bytes data memory provided on the 8XC751. Figure 1. Pin Configuration # The PC/AT Keyboard The PC/AT keyboard transmits data in a clocked serial format consisting of a start bit, 8 data bits (LSB first), an odd parity bit and a stop bit as shown in Figure 2. Besides clock and data, the 5-pin connector (Figure 3) also includes power, ground and a no connect. Note that the PS/2 keyboard interface is logically equivalent, though it uses a different connector. (A sixth pin provides an additional no connect). When a key is pressed, the PC/AT keyboard transmits a 'make' code and, when the key is released, a 'break' code. The make code consists of an 8-bit 'scan' code denoting the key pressed. The 'break' code (key released) consists of the same 8-bit scan code preceded by a special code—0F0H. A notable difference from a regular ASCII keyboard is the way SHIFT, CTRL, ALT, etc. control keys work. For an ASCII keyboard, the control keys directly modify the code output. For example, a 61H (ASCII code for 'a') is output if the 'A' key is pressed by itself, while a 41H (ASCII code for 'A') is output if the SHIFT and 'A' keys are pressed simultaneously. The PC/AT keyboard handles such a key combination as two separate key presses, i.e., SHIFT-MAKE, 'A'-MAKE, SHIFT-BREAK, 'A'-BREAK. The 'A' scan code (1CH) is the same for both the shifted and unshifted state. To determine whether the 'A' scan code is interpreted as 'A' or 'a' the PC must keep track of the presence or absence of a prior SHIFT-MAKE. # Keyboard-to-I<sup>2</sup>C Hardware (Figure 4) The 8XC751 on-chip I<sup>2</sup>C interface allows direct connection of the SDA (Serial Data) and SCL (Serial Clock) pins to the corresponding I<sup>2</sup>C bus lines. Since the I<sup>2</sup>C bus is open collector (allowing multimasters), 10K resistors are used to pull the lines to the idle state between keypresses. The PC/AT keyboard interface is equally simple. The CLK output from the keyboard is used to generate an interrupt (INTO). In response, the 8XC751 interrupt service routine samples the keyboard serial DATA connected to port 0 bit 2 (P0.2). When used with a PC, the keyboard implements a bidirectional communication protocol by exploiting the fact that both the keyboard and PC can drive the open collector CLK and DATA lines. However, bidirectional communication is not required for basic keyboard operation and in this application, the keyboard is treated as an 'input-only' device. # Keyboard-to-I<sup>2</sup>C Software The keyboard-to-I<sup>2</sup>C software performs three major functions: - Capture the clocked serial data from the keyboard - Translate the keyboard data to the corresponding ASCII code - Send the ASCII code as an I<sup>2</sup>C message. When a key is pressed, the CLK output from the keyboard generates an interrupt via INTO. The 8XC751 shifts in the DATA from the keyboard on P0.2 (port 0, bit 2) and extracts the 8-bit scan code from the 11-bit packet. Next, the scan code is interpreted and converted to the corresponding ASCII code using a look-up table. Keyboard multi-code outputs are converted to single ASCII codes by tracking the state (i.e. shifted vs. unshifted) of the keyboard and using separate look-up tables for each. For example, a keyboard SHIFT-MAKE, 'A-MAKE, SHIFT-BREAK, 'A'-BREAK sequence is converted to the ASCII code for uppercase 'A' (41H). The flowchart in Figure 5 depicts the keyboard data capture and code conversion process. The 8XC751 operates as an I<sup>2</sup>C slave. When the master issues a read command, the 8XC751 returns the converted ASCII character. The seven least significant bits are used for the ASCII code, while the most significant bit is used as a NEW flag (0 = new, 1 = old). The key code remains marked as new until the master issues a write to the 8XC751 at which point it is marked as old and will be overwritten by the next key processed. The keyboard-to-I<sup>2</sup>C software is shown immediately following Figure 5. Less than half the code space available on the 8XC751 is used, leaving room for extra features such as parity checking and more complete keyboard control state mapping using additional look-up tables. # Connecting a PC keyboard to the $I^2$ C-bus AN434 Figure 2. PC/AT Keyboard Timing Figure 3. Keyboard Connections (looking into the connector) Figure 4. IBM Keyboard to I<sup>2</sup>C Bus Format Using the 8XC751 AN434 Figure 5. Keyboard Data Capture and Conversion AN434 ``` 0001 0002 Copyright Micro AMPS Ltd 0003 0000 0000 & Philips Semiconductors 0004 0005 Dec 1990 0006 0000 ,************************ 0007 0000 8000 ; Read data under interrupt from an IBM keyboard 0009 0000 0000 ; Hardware resources: 0010 Kbd clock on interrupt INTO P1.5 0011 Kbd data on pin 0012 0000 P0.2 0013 0000 0000 0014 ; This program reads keys in from the keyboard 0015 0000 0016 0000 ; and translates them to ASCII 0017 0000 0018 0000 0019 0000 0020 0000 #include equates.51 ; direct addresses for the standard 8051 processor 0001+ 0000 0002+ 0000 0003+ 0000 .equ 80h ; port 0 p0 0004+ 0000 ; stack pointer .equ 81h sp dp1 .equ 82h ; data pointer low 0005+ 0000 ; data pointer high 0006+ 0000 dph .equ 83h 0007+ 0000 0000+ 0000 .equ 87h ; power control pcon ; timer control 0009+ 0000 tcon .equ 88h .equ 89h 0010+ 0000 ; timer mode tmod ; timer 0 low 0011+ 0000 t10 .equ 8ah ; timer 0 high .equ 8ch 0012+ 0000 th0 0013+ 0000 0014+ 0000 th1 .egu 8dh ; timer 1 high 0015+ 0000 p1 0016+ 0000 .equ 90h ; port 1 0017+ 0000 scon .egu 98h ; serial control ; serial control .equ 98h 0008+ 0000 s0con 0019+ 0000 s0buf .equ 99h ; serial data 0020+ 0000 0021+ 0000 .equ 0a0h .equ 0b0h ; port 2 p2 0022+ 0000 p3 ; port 3 0023+ 0000 ien0 .equ 0a8h ; interrupt enable 0024+ 0000 .equ 0a8h ie 0025+ 0000 0026+ 0000 .equ 0d0h ; program status word psw 0027+ 0000 ; accumulator .equ 0e0h acc 0028+ 0000 .equ 0f0h ; b register 0029+ 0000 0030+ 0000 ; bit addressed flags 0031+ 0000 0032+ 0000 it0 .equ 88h ; int 0 edge/level trigger 0033+ 0000 ; int 0 edge detect ie0 .equ 89h .equ 8ah 0034+ 0000 it1 ; int 1 edge/level trigger .equ 8bh 0035+ 0000 ; int 1 edge detect ie1 ; timer 0 enable/disable 0036+ 0000 tr0 .equ 8ch ; timer 0 overflow detect 0037+ 0000 tf0 .equ 8dh .equ 8eh ; timer 1 enable/disable 0038+ 0000 tr1 ; timer 1 overflow detect 0039+ 0000 .equ 8fh tf1 0040+ 0000 0041+ 0000 .equ 98h ri 0042+ 0000 .equ 99h 0043+ 0000 0044+ 0000 ien0.7 .equ 0afh ; global int enable/disable 0045+ 0000 .equ 080h ; port 0 bit 0 0046+ 0000 p0.0 0047+ 0000 ``` AN434 ``` 0048+ 0000 b.0 .equ 0f0h ; b reg bits 0049+ 0000 b.1 .equ 0f1h 0050+ 0000 .equ 0f2h b.2 0051+ 0000 b.3 .equ 0f3h 0052+ 0000 b.4 .equ 0f4h 0053+ 0000 b.5 .equ 0f5h .equ 0f6h 0054+ 0000 b.6 0055+ 0000 b.7 .equ 0f7h 0056+ 0000 0057+ 0000 a.0 .equ 0e0h ; accumulator bits 0058+ 0000 a.1 .equ 0e1h 0059+ 0000 a.2 .equ 0e2h 0060+ 0000 a.3 .equ 0e3h 0061+ 0000 a.4 .equ 0e4h 0062+ 0000 a.5 .equ 0e5h 0063+ 0000 a.6 .equ 0e6h 0064+ 0000 a.7 .equ 0e7h 0065+ 0000 0066+ 0000 rth .equ 8dh ; timer 0 reload high 0067+ 0000 rtl .equ 8bh ; timer 0 reload low 0068+ 0000 0021 0000 #include kbd.h 0001+ 0000 #define reg .equ 0002+ 0000 0003+ 0000 0004+ 0000 ; 8xc751 special register set 0005+ 0000 0006+ 0000 ; 751 I2C byte registers 0007+ 0000 +8000 0000 I2CON .equ 098h ; I2C control 0009+ 0000 I2CFG .equ 0d8h ; I2C configuration 0010+ 0000 I2DAT .equ 099h ; I2C data 0011+ 0000 I2STA .equ 0f8h ; I2C status 0012+ 0000 0013+ 0000 ΙE .equ 0a8h ; interrupt enable 0014+ 0000 0015+ 0000 TCON .equ 088h ; timer/counter control 0016+ 0000 0017+ 0000 \mathtt{TL} .equ 08ah ; timer 0 low 0018+ 0000 TH .equ 08ch ; timer 0 high 0000 0019+ RTL .equ 08bh ; timer reload low 0020+ 0000 RTH .egu 08dh ; timer reload high 0021+ 0000 0022+ 0000 ; 751 I2C bit registers 0023+ 0000 0024+ 0000 ; I2CNFG 0025+ 0000 0026+ 0000 SLAVEN .equ 0dfh 0027+ 0000 MASTRQ .equ 0deh 0028+ 0000 TIRUN .equ 0dch 0029+ 0000 CT1 .equ 0d9h 0030+ 0000 CT0 .equ 0d8h 0031+ 0000 CLRTI .equ 0ddh 0032+ 0000 0033+ 0000 RDAT .equ 09fh 0034+ 0000 ATN .equ 09eh 0035+ 0000 DRDY .equ 09dh 0036+ 0000 ARL .equ 09ch 0037+ 0000 STR .equ 09bh 0038+ 0000 STP .equ 09ah 0039+ 0000 MASTER .equ 099h 0040+ 0000 0041+ 0000 ; I2CON 0042+ 0000 0043+ 0000 CXA .equ 09fh 0044+ 0000 IDLE .equ 09eh 0045+ 0000 CDR .equ 09dh ``` # **AN434** ``` .equ 09ch 0046+ 0000 CARL 0047 + 0000 CSTR .equ 09bh 0048+ 0000 CSTP .equ 09ah 0049+ 0000 XSTR .equ 099h 0050+ 0000 XSTP .eau 098h 0051+ 0000 0052+ 0000 ;I2STA 0053+ 0000 0054+ 0000 XDATA .equ 0fdh .equ Ofch 0055+ 0000 XACTV .equ 0fbh MAKSTR 0056+ 0000 0057+ MAKSTP .equ Ofah 0000 0058+ 0000 ; IE bit registers 0059+ 0000 0060+ 0000 .equ Oafh ; clr to disable all interrupts 0061+ 0000 EA .equ Oach ; set to enable iic interrupt 0062+ 0000 ET2 .equ Oabh ; set to enable timer 1 overflow interrupt 0063+ 0000 ETI .equ Oaah ; set to enable ext int 1 0064+ 0000 EX1 0065+ 0000 ET0 .equ 0a9h ; set to enable timer 0 overflow interrupt .equ 0a8h ; set to enable ext int 0 0066+ 0000 0067+ 0000 ; Value definitions. 0068+ 0000 0069+ 0000 ;CT1, CT0 bit values for I2C. 0070+ 0000 CTVAL .eau 02h 0071+ 0000 0072+ 0000 ; Masks for I2CFG bits. 0073+ 0000 0074+ 0000 ; mask for TIRUN bit. 0075+ 0000 BTIR .equ 10h .equ 40h ; mask for MASTRQ bit. 0076+ 0000 BMRQ 0077+ 0000 0078+ 0000 ; Masks for I2CON bits. 0079+ 0000 +0800 0000 ; mask for CXA bit. .equ 80h 0081+ 0000 BCXA .equ 40h ; mask for IDLE bit. 0082+ 0000 RIDLE .equ 20h ; mask for CDR bit. 0083+ 0000 BCDR ; mask for CARL bit. .equ 10h 0084+ 0000 BCARL ; mask for CSTR bit. .equ 08h 0085+ 0000 BCSTR .equ 04h ; mask for CSTP bit. 0086+ 0000 BCSTP ; mask for XSTR bit. .equ 02h 0087+ 0000 BXSTR ; mask for XSTP bit. 0008+ 0000 BXSTP .equ 01h 0089+ 0000 0090+ 0000 0091+ 0000 0092+ 0000 SCL .equ p0.0 ; port bit for I2C serial clock line. .equ p0.1 ; port bit for I2C serial data line. 0093+ 0000 SDA 0094+ 0000 0022 0000 .equ 088h ; our I2C slave address 0023 0000 IICADD MAXBYTES ; max bytes to recv or trans 0024 0000 .equ 1 0025 0000 ; I2C received data buffer 0026 0000 rcvdat .equ 04h .equ 06h 0027 ; I2C transmitter buffer 0000 xmtdat 0028 0000 0029 0000 STACK .equ 08h 0030 0000 0031 0000 flags .equ 020h ; byte used as flags ; I2C flags.0, ...1, ...2, etc 0032 0000 .equ (flags-20h) .equ (flags-20h)+1 ; 0033 0000 recvd 0034 0000 sent_flag .equ (flags-20h)+2; 0035 0000 i2c_busy .equ (flags-20h)+3; 0036 0000 0037 0000 Cntrl .equ (flags-20h)+8; control key flag .equ (flags-20h)+9; shift key flag 0038 0000 Shift 0039 0000 ``` AN434 ``` 0040 0000 bitcnt .equ flags+2 0041 0000 bytecnt .equ flags+3 0042 0000 0043 0000 adrrcvd .equ flags+4 0044 .equ (adrrcvd-20h)*8 ; adrrcvd.0 0000 rwflag 0045 0000 0046 0000 tick .eau 025h ; count 10mS ticks to give 1sec tick 0047 0000 i2ctime .equ 027h ; I2C timeout - used on slow I2C bus 0048 0000 0049 0000 0050 0000 NBits .equ 29h ; # bits read so far 0051 0000 NBytes .equ NBits+1 ; # bytes in buffer 0052 0000 lastkey .equ NBytes+1 ; last key was? 0053 0000 keytemp .equ lastkey+1 ; used to build the key bit by bit 0054 0000 keybuff .equ keytemp+1 ; store the chars here 0055 0000 0056 0000 0057 0000 INMAX .equ 8 ; size of keyboard buffer 0058 0000 KEYCLK .equ p1.5 ; keyboard clock signal on ext int 0 0059 0000 KEYDAT .equ 82h ; keyboard data line 0060 0000 0061 0000 EDGEINT .equ 08ah 0062 0000 0063 0000 ; reset and interrupt vectors. 0064 0000 0065 0000 .org 0 ; reset vector 0066 0000 01 50 ajmp start 0067 0002 0068 0003 .org 0003h ; external interrupt 0 0069 0003 01 B5 ajmp kbd 0070 0005 0071 000B .org 0bh ; counter/timer 0 0072 000B 21 EA ajmp badint 0073 000D 0074 0013 .org 013h ; external interrupt 1 0075 0013 21 EA ajmp badint 0076 0015 0077 001B .org 01bh ; timer 1 - I2C timeout 0078 001B 21 DA ajmp timerI 0079 001D 0080 0023 .org 023h ; I2C interrupt 0081 0023 21 38 ajmp i2cint 0082 0025 0083 0025 0084 0048 .org 48h 0085 0048 0086 0048 done: 0087 0048 01 48 ajmp $ ; main routine waiting for key presses 0088 004A 0089 0050 .org 50h 0090 0050 0091 0050 start: 0092 0050 78 FF mov r0, #0ffh ; power supply settling time 0093 0052 79 FF mov r1,#0ffh 0094 0054 7A 04 mov r2, #04h 0095 0056 0096 0056 D8 FE dly1:djnz r0,$ 0097 0058 D9 FC djnz r1,dly1 0098 005A DA FA djnz r2,dly1 0099 005C 0100 005C reset: 0101 005C 75 80 FF mov p0, #0ffh 0102 005F 75 90 FF mov p1, #0ffh 0103 0062 75 B0 FF mov p3, #0ffh 0104 0105 0065 75 81 08 mov sp, #STACK ; initialize stack pointer 0106 0068 D2 8A setb EDGEINT ; make ext int 0 edge activated ``` # AN434 ``` 0107 006A 006A C2 09 clr Shift ; clear keyboard shift flag 0108 006C 0109 006C 78 29 mov r0, #NBits ; clear the input buffers 0110 006E 79 10 mov r1,#10h 0111 0070 75 E0 00 mov acc,#0 0112 0113 0073 ; do the clearing 0114 0073 F6 clrlp:mov @r0,a 0074 08 inc r0 0115 0116 0075 D9 FC djnz r1,clrlp 0117 0077 ; transmit buffer filled with mov xmtdat, #'.' 0118 0077 ; mov xmtdat+1,#0ffh 0119 0077 ; $ff when empty ; 0120 0077 0121 0077 75 20 00 mov flags, #0 0122 007A 75 27 00 mov i2ctime, #0 0123 007D 0124 007D restart: 0125 007D ; enable slave functions 0126 007D 75 D8 82 mov I2CFG, #80h+CTVAL 0127 0080 75 98 40 mov I2CON, #BIDLE ; place in idle state 0128 0083 ; enable external & IIC interrupts 0129 0083 75 A8 91 mov ien0, #91h 0130 0086 0131 0086 ;***** Main loop ***** 0132 0086 0133 0086 0134 0086 main: ; if data in keybuff then 0135 0086 E5 2A mov a, NBytes 0136 0088 60 OC iz empty ; copy to I2C xmt buffer 0137 008A 008A 75 A8 00 mov ien0, #0h ; disable all ints temporarily 0138 008D 85 2D 06 mov xmtdat, keybuff 0139 ; clear keyboard buffer full flag 0140 0090 75 2A 00 mov NBytes,#0 ; enable external&IIC interrupts 0141 0093 75 A8 91 mov ien0, #91h 0096 0142 0143 0096 empty: 0144 0096 0096 30 01 0A jnb recvd, notread ; recvd flag tells 751 to clear 0145 ; I2C xmt buffer when I2C master 0146 0099 ; reads the data from the 751 0147 0099 85 06 E0 mov acc, xmtdat 0148 009C 44 80 orl a, #80h ; the master writes any data 009E 85 E0 06 mov xmtdat,acc ; back which will set the MSB of 0149 ; the data buffer. This is reqd. 0150 00A1 0151 00A1 ; to sync the two processors. 0152 00A1 C2 01 clr recvd ; reset I2C received flag 0153 00A3 0154 00A3 notread: 0155 00A3 ; detect alt key for special 0156 00A3 E5 2B mov a, lastkey clr c 0157 00A5 C3 ; for special functions 0158 subb a,#11h 00A6 94 11 jnz notalt 0159 00A8 70 01 0160 00AA 0161 ; alt code goes here 00AA 00 nop 0162 OOAB 0163 00AB notalt: 0164 00AB E5 2A mov a, NBytes 0165 00AD C3 clr c 00AE 94 08 subb a, #INMAX ; limit the input buffer to INMAX 0166 00B0 40 01 ; if data is buffered 0167 jc notdone 0168 00B2 ; then buffer overflow 00B2 00 ; code goes here 0169 nop 0171 00B3 00B3 0172 notdone: 0173 0174 00B3 80 D1 sjmp main ; go back to start ``` AN434 ``` 0175 00B5 ;***** End of Main loop ***** 0176 00B5 0177 0178 00B5 0179 00B5 ; ***** External int 0 ISR *****; 0180 00B5 ٠; ; keyboard interrupt service routine ; 0181 00B5 0182 00B5 0183 0184 00B5 0185 00B5 0186 00B5 kbd: 0187 00B5 C0 D0 push psw ; save .equs during ISR 00B7 C0 E0 0188 push acc 0189 00B9 0190 00B9 85 29 E0 mov acc, NBits ; NBits=bit number next expected 0191 00BC ; from the keyboard 0192 00BC B4 00 02 cjne a, #0, bit1 8 ; if not bit 0 then bit 1 to 8 0193 00BF 0194 00BF 0195 00BF ;***** Keyboard Bit 0 ***** 0196 00BF 0197 00BF 0198 00BF ; discard bit 0 - Start bit 00BF 80 70 0199 sjmp bump 0200 00C1 0201 00C1 0202 00C1 ;***** Keyboard Bit 1-8 ***** 0203 00C1 0204 00C1 bit1_8: 0205 00C1 B4 09 00 cjne a, #9,$+3 ; CY flag is set if acc < 9 0206 00C4 50 0C jnc bit9 0207 00C6 0208 00C6 A2 82 mov c, KEYDAT ; read data for keyboard data line 0209 00C8 E5 2C mov a, keytemp ; data arrives least sig bit 1st 0210 00CA 03 rr a ; hence old value is rotated and new 0211 00CB 92 E7 mov a.7,c ; bit is or'ed to the msb 00CD 85 E0 2C mov keytemp,acc 0212 0213 00D0 80 5F sjmp bump 0214 0002 0215 00D2 0216 00D2 ;***** Bit 9 ***** 0217 00D2 0218 00D2 bit9: 0219 00D2 B4 09 02 cjne a, #9, bit10 0220 00D5 0221 00D5 80 5A sjmp bump ; parity check code would go here 0222 00D7 0223 00D7 0224 00D7 0225 0007 ;***** Bit 10 ***** 0226 00D7 0227 00D7 ; The stop bit - Key Scan is now complete so convert to ASCII 0228 00D7 0229 00D7 bit10: 0230 00D7 85 2C E0 mov acc, keytemp ; get next key 0231 00DA 00DA B4 12 14 0232 cjne a,#12h,notls ; is it the left shift char? 0233 00DD 0234 00DD 0235 00DD ;***** Left Shift has Been Pressed ***** 0236 00DD 0237 00DD 85 2B E0 mov acc, lastkey ; if last key was 0238 00E0 B4 F0 07 cjne a,#0f0h,makels ; $f0 then shift is released 0239 00E3 0240 00E3 C2 09 clr Shift ; next keys will be unshifted 00E5 75 2B 12 mov lastkey, #12h ; copy left shift key to last key ``` AN434 ``` 0242 00E8 80 3F sjmp tidy 0243 00EA 0244 00EA makels: ; next keys will be shifted 00EA D2 09 setb Shift 0245 ; copy left shift key to last key 00EC 75 2B 12 mov lastkey, #12h 0246 0247 00EF 80 38 sjmp tidy 0248 00F1 ;***** End of Shift Routine ***** 0249 00F1 0250 00F1 0251 00F1 notls: ; get next key 0252 00F1 mov acc, keytemp ; is it a control char? 00F1 B4 14 03 cjne a, #14h, notctrl 0253 0254 0255 00F4 ;***** Control State ***** 0256 00F4 0257 ; control state goes here 0258 00F4 00 nop 0259 00F5 80 32 sjmp tidy 0260 ;***** End of Control State ***** 0261 00F7 0262 00F7 0263 00F7 notctrl: 0264 00F7 00F7 B4 F0 04 cjne a, #0f0h, notbreak; if current key $f0 then break 0265 00FA 0266 ;***** Key Break ***** 0267 00FA 0268 00FA ; record break code in last key 0269 00FA F5 2B mov lastkey,a ; but don't store in the buffer 0270 00FC 80 2B sjmp tidy 0271 00FE 0272 00FE notbreak: 0273 OOFE 00FE 85 2B E0 mov acc, lastkey ; if last key was $f0 then 0274 0101 B4 F0 05 cjne a, #0f0h, not_f0 ; ignore the next scan code 0275 0276 0104 ; which is a break code 0104 75 2B 00 mov lastkey, #0 0277 0278 0107 80 20 sjmp tidy 0279 0109 0280 0109 not_f0: 0281 0109 0282 0109 ;***** Normal Key Press ***** 0109 0283 0284 0109 0285 0109~ #ifdef buffered 0109~ 0109~ ;***** Buffered Code ***** 0287 0109~ 0288 0289 0109~ ; buffered code 0109~ ; r0 used as an indirect pointer 0290 push 0 0109~ ; so save it 0291 0292 0109~ mov acc, #keybuff ; copy data into keyboard 0293 0109~ add a,NBytes 0109~ 0294 mov r0,a 0295 0109~ ; get current key 0296 0109~ mov a, keytemp 0109~ ; & copy to lastkey 0297 mov lastkey,a 0298 0109~ 0299 0109~ push dph ; dp used to point to xlat tables 0300 0109~ push dpl ; since in ISR save dp contents 0109~ 0301 ; if in unshifted state 0302 0109~ jb Shift, shifted 0109~ mov dptr, #unshift ; use the unshift table 0303 0109~ 0304 sjmp skip1 0305 0109~ 0109~ shifted: 0306 0109~ mov dptr, #shift ; else use the shift table 0307 0308 0109~ ``` # AN434 ``` 0309 0109~ skip1: 0310 0109~ movc a,@a+dptr ; translate char in Acc to Ascii 0311 0109~ 0312 0109~ pop dpl ; restore the data pointer 0313 0109~ pop dph 0314 0109~ 0315 0109~ cjne a, #0, Not0 ; if data is zero discard 0316 0109~ 0317 0109~ ; sjmp NoSave ; discard code goes here 0318 0109~ 0319 0109~ Not0: 0320 0109~ mov r0, #keybuff ; Save ascii value in buffer 0321 0109~ mov @r0,a ; buffered keyboard entry 0322 0109~ inc NBytes 0323 0109~ 0324 0109~ NoSave: 0325 0109~ pop 0 ; restore r0 0326 0109~ 0327 0109~ ;**** End of Buffered Code 0328 0109~ 0329 0109 #endif 0330 0109 0331 0109 0332 0109 #define unbuffered 1 0333 0109 0334 0109 #ifdef unbuffered 0335 0109 0336 0109 E5 2C mov a, keytemp ; get current key 0337 010B F5 2B mov lastkey, a ; & copy to lastkey 0338 010D 0339 010D C0 83 push dph ; dp used to point to xlat tables 0340 010F C0 82 push dpl ; since in ISR save dp contents 0341 0111 0342 0111 20 09 05 jb Shift, shifted ; if in unshifted state 0343 0114 90 01 EB mov dptr, #unshift ; use the unshift table 0344 0117 80 03 sjmp skip1 0345 0119 0346 0119 shifted: 0119 90 02 6B mov dptr, #shift 0347 ; else use the shift table 0348 011C 0349 011C skip1: 011C 93 0350 movc a,@a+dptr ; translate char in Acc to Ascii 0351 011D 0352 011D D0 82 pop dpl ; restore the data pointer 0353 011F D0 83 pop dph 0354 0121 0355 0121 B4 00 00 cjne a,#0,Not0 ; if data is zero discard 0356 0124 0124 0357 ; sjmp tidy ; discard code goes here 0124 0358 0359 0124 Not0: 0360 0124 F5 2D mov keybuff, a ; store in keyboard buffer 0126 75 2A 01 0361 mov NBytes,#1 ; mark byte read 0362 0129 0129 0363 tidy: 0364 0129 75 29 00 mov NBits,#0 ; clear flags ready for next key 0365 012C 75 2C 00 mov keytemp, #0 0366 012F 80 02 sjmp intdone 0367 0131 0368 0131 ;***** End of Keyboard Translation and Save ***** 0369 0131 0370 0131 0371 0131 ;***** Normal unfinished key exit ***** 0372 0131 0373 0131 bump: 0374 0131 05 29 inc NBits ; inc number of bits read so far 0375 0133 ``` # AN434 ``` 0376 0133 intdone: pop acc 0377 0133 D0 E0 0378 0135 D0 D0 pop psw 0379 0137 32 reti 0380 0138 0138 ;***** End of Ext Int 0 ISR ***** 0381 0138 0382 0383 0138 0384 0138 0138 0385 ;***** I2C CODE SLAVE ***** 0386 0138 0387 0138 ; I2C interrupt entry point 0138 0388 i2cint: ; semaphore on xmtdata buffer 0138 D2 03 setb i2c_busy 0389 0390 013A push psw ; save registers used in ISR 013A C0 D0 0391 push acc 0392 013C C0 E0 ; R0 no bank switching 0393 013E CO 00 push 0 0394 0140 ; make I2C ISR interruptable 0395 ; execute a reti 0396 0397 0144 0398 0144 slave: ; set up I2C timeout watchdog 30 mS 0144 75 27 03 mov i2ctime,#3 0399 0400 0147 0401 0147 75 98 9C mov I2CON, #BCARL+BCSTP+BCSTR+BCXA : clear start status 0402 014A 0403 014A ; wait for next data bit 0404 014A 30 9E FD jnb ATN,$ 014D 75 22 07 mov bitcnt, #7 0405 0150 0406 ; get remainder of slave address 0407 0150 31 C9 acall recvb2 0408 0152 F5 24 mov adrrcvd,a ; mask r/w bit to check address 0409 0154 C2 E0 clr a.0 0156 B4 88 3B cjne a, #IICADD, goidle ; idle again if not for us 0410 0411 0159 0412 0159 20 20 1F jb rwflag, read ; test for read or write 0413 015C 015C 0414 0415 015C ;***** I2C Receive Code ***** 0416 015C 0417 0150 ; r0 points to data buffer 015C 78 04 mov r0, #rcvdat 0418 015E 75 23 01 mov bytecnt, #MAXBYTES 0419 0420 0161 0421 0161 rcvloop: acall sendack ; acknowledge the address 0422 0161 31 BF ; wait for the next data byte 0423 0163 31 C6 acall rcvbyte 0424 0165 30 9D OF inb DRDY, exitwr ; end of frame 0425 0168 F6 mov @r0,a 0426 inc r0 0169 08 016A D5 23 F4 djnz bytecnt,rcvloop 0427 0428 016D 0429 016D ; no more room 0430 016D 0431 016D 31 BF acall sendack ; ack last byte ; get but discard next one 0432 016F 31 C6 acall rcvbyte 0171 75 99 80 mov I2DAT, #80h 0174 30 9E FD jnb ATN,$ ; send neg ack 0433 ; wait till gone 0434 0435 0177 exitwr: 0177 0436 0437 0177 D2 01 setb recvd 0438 0179 80 13 sjmp msgend 0439 017B ;***** End of Receive Routine ***** 0440 017B 0441 017B 0442 017B ``` AN434 ``` 0443 017B ;***** I2C Transmit Code ***** 0444 017B 0445 017B read: 0446 017B 78 06 mov r0, #xmtdat ; r0 points to data buffer 0447 017D 75 23 01 mov bytecnt, #MAXBYTES 0448 0180 31 BF acall sendack ; acknowledge address 0449 0182 0450 0182 txloop: 0451 0182 E6 mov a,@r0 ; get next data byte 0452 0183 08 inc r0 ; bump buffer pointer acall xmitbyte 0453 0184 31 A7 ; transmit the byte to the I2C 0186 20 00 03 jb noack, exitrd 0189 D5 23 F6 djnz bytecnt, txloop 0454 ; if not acknowledged then exit 0455 0456 018C 0457 018C 80 00 exitrd: sjmp msgend 0458 018E 0459 ;***** End of I2C transmit ***** 018E 0460 018E 0461 018E 0462 018E ;***** Repeated start state ***** 0463 018E msgend: 0464 018E 30 9E FD jnb ATN,$ ; wait for stop or repeated start 0465 0191 20 9B B0 jb STR,slave ; if repeat start do again 0466 0194 0467 0194 ; stop so enter idle mode 0468 0194 0469 0194 goidle: 0194 75 27 00 mov i2ctime,#0 0470 ; stop I2C timeout 0197 75 98 F4 mov I2CON, #BCSTP+BCXA+BCDR+BCARL+BIDLE 0471 0472 019A 0473 019A DO OO pop 0 ; restore state before T2C TSR 0474 019C D0 E0 pop acc 0475 019E D0 D0 pop psw 0476 01A0 setb EI2 0477 01A0 D2 AC 0478 01A2 D2 02 setb sent_flag ; flag to say data has been sent 0479 01A4 C2 03 clr i2c_busy ; flag denotes exiting I2C routine 0480 01A6 0481 01A6 22 0482 01A7 0483 01A7 01A7 ;***** General I2C routines ***** 0484 0485 01A7 0486 01A7 xmitbyte: ; transmit data in acc to I2C 0487 01A7 75 22 08 mov bitcnt,#8 0488 01AA 0489 01AA xmitbit: 01AA F5 99 mov I2DAT,a 0490 0491 01AC 23 rla 0492 01AD 30 9E FD jnb ATN,$ 0493 01B0 D5 22 F7 djnz bitcnt,xmitbit 0494 01B3 75 98 A0 mov I2CON,#BCDR+BCXA ; switch to rcv mode 0495 01B6 30 9E FD jnb ATN,$ ; wait for ack 0496 01B9 85 99 20 mov flags,I2DAT ; save ack bit 0497 01BC 22 ret 0498 01BD 0499 01BD 0500 01BD 0501 01BD rdack: ; receives data byte then sends ack 0502 01BD 31 C6 acall rcvbyte ; I2C receive, data returned in acc 0503 01BF 0504 01BF sendack: 01BF 75 99 00 mov I2DAT,#0 0505 ; I2C ack = data low and clock high 0506 01C2 30 9E FD jnb ATN,$ 01C5 22 0507 0508 01C6 01C6 rcvbyte: ; I2C receive, data returned in acc ``` # AN434 ``` 0510 01C6 75 22 08 mov bitcnt, #8 0511 01C9 01C9 E4 recvb2: clr a 0512 01CA 0513 rbit: orl a,I2DAT 01CA 45 99 0514 01CC 23 0515 rl a 0516 01CD 30 9E FD jnb ATN,$ jnb DRDY,rbex 01D0 30 9D 06 ; exit if not a data bit 0517 0518 01D3 D5 22 F4 djnz bitcnt,rbit 0519 01D6 ; get last bit - do not clear ATN 0520 01D6 A2 9F mov c, RDAT ; shift into byte 0521 01D8 33 rlc a 0522 01D9 0523 01D9 rbex: 0524 01D9 22 ret 0525 01DA 0526 01DA IIC timer interrupt service 0527 01DA timerI: ; break point address in ICE751 0528 01DA 75 A8 00 mov ien0,#0 ; clear the interrupt 01DD D2 DD setb CLRTI 0529 0530 01DF fixup: ; turn off I2C 0531 01DF 75 D8 00 mov I2CFG,#0 01E2 75 98 BC mov I2CON, #BCXA+BCDR+BCARL+BCSTR+BCSTP 0532 ; reset I2C flags 0533 01E5 0534 01E5 31 E9 acall clrint 01E7 01 5C ; restart program 0535 ajmp reset 0536 01E9 0537 01E9 ;***** call here to make code interruptible ****** 0538 01E9 0539 01E9 0540 01E9 clrint: 0541 01E9 32 reti 01EA 0542 ;***** unused interrupts are vectored to here ***** 0543 01EA 0544 01EA badint: 0545 01EA 32 reti 0546 01EB 0547 01EB #include attable.h ; scan code 0001+ 01EB unshift .byte 0 ; 0 0002+ 01EB 00 .byte 0 ; 1 - f9 0003+ 01EC 00 ; 2 - f7 0004+ 01ED 00 .byte 0 0005+ 01EE 00 ; 3 - f5 .byte 0 ; 4 - f3 0006+ 01EF 00 .byte 0 0007+ 01F0 00 .byte 0 ; 5 - f1 ; 6 - f2 0008+ 01F1 00 .byte 0 .byte 0 0009+ 01F2 00 0010+ 01F3 00 ; 7 - f2 ; 8 - .byte 0 0011+ 01F4 00 ; 9 - f10 .byte 0 0012+ 01F5 00 .byte 0 ; a - f8 0013+ 01F6 00 .byte 0 ; b - f6 ; c - f4 .byte 0 0014+ 01F7 00 .byte 09h 0015+ 01F8 09 0016+ 01F9 60 ; d - tab .byte ''' ; e - ' 0017+ 01FA 00 ; f - .byte 0 0018+ 01FB 0019+ 01FB 00 .byte 0 ; 10 .byte 0 ; 11 - left shift 0020+ 01FC 00 .byte 0 0021+ 01FD 00 ; 12 0022+ 01FE 00 .byte 0 ; 13 0023+ 01FF 00 .byte 0 ; 14 0024+ 0200 71 .byte 'q' ; 15 .byte '1' 0025+ 0201 31 ; 16 .byte 0 ; 17 0026+ 0202 00 .byte 0 ; 18 0027+ 0203 00 0028+ 0204 00 .byte 0 ; 19 .byte 'z' ; la 0029+ 0205 7A ``` AN434 # Connecting a PC keyboard to the I<sup>2</sup>C-bus | 0030+ | 0206 73 | .byte 's' | | b | |----------------|--------------------|-----------|--------------|---| | 0031+ | 0207 61 | .byte 'a' | ; 1 | C | | 0032+ | 0208 77 | .byte 'w' | ; 1 | d | | 0033+ | 0209 32 | .byte '2' | ; 1 | e | | 0034+ | 020A 00 | .byte 0 | ; 1 | f | | 0035+ | 020B | | | | | 0036+ | 020B 00 | .byte 0 | ; 2 | 0 | | 0037+ | 020C 63 | .byte 'c' | ; 2 | 1 | | 0038+ | 020D 78 | .byte 'x' | ; 2 | 2 | | 0039+ | 020E 64 | .byte 'd' | ; 2 | | | 0040+ | 020F 65 | .byte 'e' | ; 2 | | | 0041+ | 0210 34 | .byte '4' | ; 2 | | | 0042+ | 0211 33 | .byte '3' | ; 2 | | | 0043+ | 0212 00 | .byte 0 | ; 2 | | | 0044+ | 0213 00 | .byte 0 | ; 2 | | | 0045+ | 0214 20 | .byte '' | ; 2 | | | 0046+ | 0215 76 | .byte 'v' | ; 2 | | | 0047+ | 0216 66 | .byte 'f' | ; 2 | | | 0048+ | 0217 74 | .byte 't' | ; 2 | | | 0049+<br>0050+ | 0218 72<br>0219 35 | .byte 'r' | .; 2 | | | 0050+ | 0219 33<br>021A 00 | .byte '5' | ; 2 | | | 0051+ | 021A 00 | .byte 0 | ; 2 | Ι | | 0052+ | 021B 00 | .byte 0 | ; 3 | n | | 0054+ | 021C 6E | .byte 'n' | ; 3 | | | 0055+ | 021D 62 | .byte 'b' | ; 3: | | | 0056+ | 021E 68 | .byte 'h' | ; 3: | | | 0057+ | 021F 67 | .byte 'g' | ; 3 | | | 0058+ | 0220 79 | .byte 'y' | ; 3! | | | 0059+ | 0221 36 | .byte '6' | ; 3 | | | 0060+ | 0222 00 | .byte 0 | ; 3' | | | 0061+ | 0223 00 | .byte 0 | ; 38 | 3 | | 0062+ | 0224 00 | .byte 0 | ; 39 | 9 | | 0063+ | 0225 6D | .byte 'm' | ; 38 | a | | 0064+ | 0226 6A | .byte 'j' | ; 31 | Э | | 0065+ | 0227 75 | .byte 'u' | ; 30 | | | 0066+ | 0228 37 | .byte '7' | ; 30 | | | 0067+ | 0229 38 | .byte '8' | ; 36 | | | 0068+ | 022A 00 | .byte 0 | ; 31 | Ē | | 0069+ | 022B | | | | | 0070+ | 022B 00 | .byte 0 | ; 40 | | | 0071+ | 022C 2C | .byte ',' | ; 4: | | | 0072+ | 022D 6B<br>022E 69 | .byte 'k' | ; 42 | | | 0074+ | 022E 69 | .byte 'i' | ; 43 | | | 0075+ | 0230 30 | .byte 'o' | ; 44<br>; 45 | | | 0076+ | 0230 30 | .byte '9' | ; 45<br>; 46 | | | 0077+ | 0232 00 | .byte 0 | ; 47 | | | 0078+ | 0233 00 | .byte 0 | ; 48 | | | 0079+ | 0234 2E | .byte '.' | ; 49 | | | 0080+ | 0235 2F | .byte '/' | ; 45 | | | 0081+ | 0236 6C | .byte 'l' | ; 4h | | | 0082+ | 0237 00 | .byte ';' | ; 40 | | | 0083+ | 0238 70 | .byte 'p' | ; 40 | | | 0084+ | 0239 2D | .byte '-' | ; 4 | 9 | | 0085+ | 0234 00 | byte 0 | . 14 | | 1992 Aug 26 160 .byte 0 .byte 0 .byte ',' .byte 0 .byte 0 .byte '[' .byte '=' .byte 0 .byte 0 .byte 0 .byte 0 ; 50 ; 51 ; 52 ; 53 ; 54 ; 55 ; 56 ; 57 ; 59 ; 58 0085+ 023A 00 0088+ 023C 2C 0089+ 023D 00 0090+ 023E 00 0091+ 023F 5B 0092+ 0240 3D 0093+ 0241 00 0094+ 0242 00 0095+ 0243 00 0096+ 0244 00 0086+ 023B 0087+ 023B 00 # Connecting a PC keyboard to the $I^2$ C-bus AN434 | 0097+ | 0245 OD | .byte 13 | ; 5a | |----------------|--------------------|--------------------|--------------| | 0098+ | 0246 5D | .byte ']' | ; 5b | | 0099+ | 0247 00 | .byte 0 | ; 5c | | 0100+ | 0248 5C | .byte 92 | ; 5d | | 0101+ | 0249 00 | .byte 0 | ; 5e | | 0102+ | 024A 00 | .byte 0 | ; 5f | | 0103+ | 024B | | , | | 0104+ | 024B 00 | .byte 0 | ; 60 | | 0105+ | 024C 00 | .byte 0 | ; 61 | | 0106+ | 024D 00 | .byte 0 | ; 62 | | 0107+ | 024E 00 | .byte 0 | ; 63 | | 0108+ | 024F 00 | .byte 0 | ; 64 | | 0109+ | 0250 00 | .byte 0 | ; 65 | | 0110+ | 0251 08 | .byte 8 | ; 66 | | 0111+ | 0252 00 | .byte 0 | ; 67 | | 0112+ | 0253 00 | .byte 0 | ; 68 | | 0113+ | 0254 00 | .byte 0 | ; 69 | | 0114+ | 0255 00 | .byte 0 | ; 6a | | 0115+ | 0256 00 | .byte 0 | ; 6b | | 0116+ | 0257 00 | .byte 0 | ; 6c | | 0117+ | 0258 00 | .byte 0 | ; 6d | | 0118+ | 0259 00 | .byte 0 | ; 6e | | 0119+ | 025A 00 | .byte 0 | ; 6f | | 0120+ | 025B | | | | 0121+ | 025B 00 | .byte 0 | ; 70 | | 0122+ | 025C 7F | .byte 127 | ; 71 | | 0123+ | 025D 00 | .byte 0 | ; 72 | | 0124+ | 025E 00 | .byte 0 | ; 73 | | 0125+ | 025F 00 | .byte 0 | ; 74 | | 0126+ | 0260 1B | .byte 27 | ; 75 | | 0127+ | 0261 00 | .byte 0 | ; 76 | | 0128+ | 0262 00 | .byte 0 | ; 77 | | 0129+ | 0263 00 | .byte 0 | ; 78 | | 0130+ | 0264 2B | .byte '+' | ; 79 | | 0131+ | 0265 00 | .byte 0 | ; 7a | | 0132+ | 0266 2D | .byte '-' | ; 7b | | 0133+ | 0267 2A | .byte '*' | ; 7c | | 0134+ | 0268 00 | .byte 0 | ; 7d | | 0135+ | 0269 00 | .byte 0 | ; 7e | | 0136+ | 026A 00 | .byte 0 | ; 7f | | 0137+ | 026B | | | | 0138+ | 026B shift: | | ; scan code | | 0139+ | 026B 00 | .byte 0 | ; 0 | | 0140+ | 026C 00 | .byte 0 | ; 1 - f9 | | 0141+ | 026D 00 | .byte 0 | ; 2 - f7 | | 0142+ | 026E 00 | .byte 0 | ; 3 - f5 | | 0143+ | 026F 00 | .byte 0 | ; 4 - f3 | | 0144+ | 0270 00 | .byte 0 | ; 5 - f1 | | 0145+ | 0271 00 | .byte 0 | ; 6 - f2 | | 0146+ | 0272 00 | .byte 0 | ; 7 - f2 | | 0147+ | 0273 00 | .byte 0 | ; 8 - | | 0148+ | 0274 00 | .byte 0 | ; 9 - f10 | | 0149+ | 0275 00 | .byte 0 | ; a - f8 | | 0150+ | 0276 00 | .byte 0 | ; b - f6 | | 0151+ | 0277 00 | .byte 0 | ; c - f4 | | 0152+ | 0278 00 | .byte 0 | ; d - tab | | 0153+ | 0279 7E | . Dy Ce | ; e - ~ | | 0154+ | 027A 00 | .byte 0 | ; f - | | 0155+ | 027B | burto 0 | . 10 | | 0156+ | 027B 00 | .byte 0 | ; 10 | | 0157+ | 027C 00 | .byte 0<br>.byte 0 | ; 11 - | | 0158+<br>0159+ | 027D 00<br>027E 00 | .byte 0 | ; 12<br>; 13 | | 0159+ | 027E 00 | .byte 0 | ; 13<br>; 14 | | 0160+ | 0280 51 | .byte 'Q' | ; 15 | | 0161+ | 0281 21 | .byte (!' | ; 16 | | 0162+ | 0282 00 | .byte 0 | ; 17 | | OT02+ | 0202 00 | .Dyte U | , 1 | # Connecting a PC keyboard to the $I^2$ C-bus AN434 | 0164+ | 0283 00 | .byte 0 | ; 18 | |-------|--------------------|------------|--------------| | 0165+ | 0284 00 | .byte 0 | ; 19 | | 0166+ | 0285 5A | .byte 'Z' | ; 1a | | 0167+ | 0286 53 | .byte 'S' | ; 1b | | 0168+ | 0287 41 | .byte 'A' | | | 0169+ | 0288 57 | .byte 'W' | | | 0170+ | 0289 40 | | | | 0170+ | 028A 00 | | ; 1e | | 0172+ | 028B | .byte 0 | ; 1f | | 0172+ | | h 0 | | | 0174+ | | .byte 0 | ; 20 | | 0175+ | | .byte 'C' | ; 21 | | 0176+ | | .byte 'X' | ; 22 | | 0177+ | 028E 44<br>028F 45 | .byte 'D' | ; 23 | | 0177+ | | .byte 'E' | ; 24 | | | 0290 24 | .byte '\$' | ; 25 | | 0179+ | 0291 23 | .byte '#' | ; 26 | | 0180+ | 0292 00 | .byte 0 | ; 27 | | 0181+ | 0293 00 | .byte 0 | ; 28 | | 0182+ | 0294 20 | .byte '' | ; 29 | | 0183+ | 0295 56 | .byte 'V' | ; 2a | | 0184+ | 0296 46 | .byte 'F' | ; 2b | | 0185+ | 0297 54 | .byte 'T' | ; 2c | | 0186+ | 0298 52 | .byte 'R' | ; 2d | | 0187+ | 0299 25 | .byte '' | ; 2e | | 0188+ | 029A 00 | .byte 0 | ; 2f | | 0189+ | 029B | | | | 0190+ | 029B 00 | .byte 0 | ; 30 | | 0191+ | 029C 4E | .byte 'N' | ; 31 | | 0192+ | 029D 42 | .byte 'B' | ; 32 | | 0193+ | 029E 48 | .byte 'H' | ; 33 | | 0194+ | 029F 47 | .byte 'G' | ; 34 | | 0195+ | 02A0 59 | .byte 'Y' | ; 35 | | 0196+ | 02A1 5E | .byte '^' | ; 36 | | 0197+ | 02A2 00 | .byte 0 | ; 37 | | 0198+ | 02A3 00 | .byte 0 | ; 38 | | 0199+ | 02A4 00 | .byte 0 | ; 39 | | 0200+ | 02A5 4D | .byte 'M' | ; 3a | | 0201+ | 02A6 4A | .byte 'J' | ; 3b | | 0202+ | 02A7 55 | .byte 'U' | ; 3c | | 0203+ | 02A8 26 | .byte '&' | ; 3d | | 0204+ | 02A9 2A | .byte '*' | ; 3e | | 0205+ | 02AA 00 | .byte 0 | ; 3f | | 0206+ | 02AB | | | | 0207+ | 02AB 00 | .byte 0 | ; 40 | | 0208+ | 02AC 3C | .byte '<' | ; 41 | | 0209+ | 02AD 4B | .byte 'K' | ; 42 | | 0210+ | 02AE 49 | .byte 'I' | ; 43 | | 0211+ | 02AF 4F | .byte '0' | ; 44 | | 0212+ | 02B0 29 | .byte ')' | ; 45 | | 0213+ | 02B1 28 | .byte '(' | ; 46 | | 0214+ | 02B2 00 | .byte 0 | ; 47 | | 0215+ | 02B3 00 | .byte 0 | ; 48 | | 0216+ | 02B4 3E | .byte '>' | ; 49 | | 0217+ | 02B5 3F | .byte '?' | ; 4a | | 0218+ | 02B6 4C | .byte 'L' | ; 4b | | 0219+ | 02B7 3A | .byte ':' | ; 4c | | 0220+ | 02B8 50 | .byte 'P' | ; 4d | | 0221+ | 02B9 5F | .byte '_' | ; 4e | | 0222+ | 02BA 00 | .byte 0 | , 46<br>; 4f | | 0223+ | 02BB | | , 11 | | 0224+ | 02BB 00 | .byte 0 | ; 50 | | 0225+ | 02BC 00 | .byte 0 | ; 50<br>; 51 | | 0226+ | 02BD 22 | .byte '"' | | | 0227+ | 02BE 00 | .byte 0 | | | 0227+ | 02BF 7B | .byte '{' | | | 0229+ | 02C0 2B | .byte (+' | | | 0230+ | 02C0 2B | | ; 55 | | 02307 | 0201 00 | .byte 0 | ; 56 | AN434 ``` 0231+ 02C2 00 .byte 0 ; 57 0232+ 02C3 00 .byte 0 .byte 0 ; 59 0233+ 02C4 00 ; 5a 0234+ 02C5 0D .byte 13 0235+ 02C6 7D .byte '}' ; 5b 0236+ 02C7 00 .byte 0 ; 5c .byte '|' ; 5d 0237+ 02C8 7C 0238+ 02C9 00 .byte 0 ; 5e 0239+ 02CA 00 .byte 0 ; 5f 0240+ 02CB 0241+ 02CB 00 .byte 0 0242+ 02CC 00 .byte 0 ; 61 0243+ 02CD 00 .byte 0 ; 62 0244+ 02CE 00 .byte 0 ; 63 0245+ 02CF 00 .byte 0 64 ; 65 0246+ 02D0 00 .byte 0 0247+ 02D1 08 .byte 8 ; 66 0248+ 02D2 00 .byte 0 ; 67 ; 68 0249+ 02D3 00 .byte 0 0250+ 02D4 31 .byte '1' ; 69 .byte 0 0251+ 02D5 00 ; 6a ; 6b 0252+ 02D6 34 .byte '4' .byte '7' 0253+ 02D7 37 ; 6c 0254+ 02D8 00 ; 6d .byte 0 0255+ 02D9 00 .byte 0 ; 6e 0256+ 02DA 00 .byte 0 ; 6f 0257+ 02DB 0258+ 02DB 30 .byte '0' ; 70 0259+ 02DC 2E .byte '.' ; 71 0260+ 02DD 32 .byte '2' ; 72 0261+ 02DE 35 .byte '5' ; 73 .byte '6' 0262+ 02DF 36 ; 74 .byte '8' 0263+ 02E0 38 75 0264+ 02E1 1B .byte 27 ; 76 ; 77 0265+ 02E2 00 .byte 0 ; 78 0266+ 02E3 00 .byte 0 .byte '+' 0267+ 02E4 2B ; 79 .byte '3' 0268+ 02E5 33 .byte '-' 02E6 2D 0269+ ; 7b ; 7c 0270+ 02E7 00 .byte 0 0271+ 02E8 39 .byte '9' ; 7d .byte 0 0272+ 02E9 00 ; 7e 0273+ 02EA 00 .byte 0 ; 7f 0274+ 02EB 0275+ 02EB 0548 02EB 0549 02EB tasm: Number of errors = 0 ``` **AN438** # Philips Semiconductors Application Note EIE/AN90015 ### Summary This application note presents a set of software routines to drive the I<sup>2</sup>C interface in 8xC528 type of microcontrollers. A description of the I<sup>2</sup>C interface is given. Examples show how to use these routines in PL/M-51, C and assembly source code. ## 1.0 INTRODUCTION This application note describes the $\rm I^2C$ interface of the 8xC528 microcontroller and gives a set of routines in application programs to drive this interface. Chapter 2.0 gives a hardware description of the bit level I<sup>2</sup>C. It gives an overview of what functions are done in hardware by the interface and the functions that should be implemented by software. The registers described are accessible with software and control the I<sup>2</sup>C interface. Chapter 3.0 gives a description of the routines that may be used by the application program. The routines are written in such a way that the I<sup>2</sup>C interface becomes transparent to the user, the slave program is described in more detail, because this routine may be adapted by the user for his specific application. Chapter 4.0 gives simple example programs that show how to use the routines in assemble, PL/M and C application programs. #### References: The I<sup>2</sup>C-bus specification 9398 358 10011 80C51-based 8-bit Microcontrollers Data handbook IC20 - PLM51 I<sup>2</sup>C Software Interface IIC51 ETV/AN89004 # 2.0 THE I<sup>2</sup>C INTERFACE ## 2.1 Characteristics of I<sup>2</sup>C Interface The Block diagram of the bit-level I<sup>2</sup>C interface is shown on page 165. P1.6/SCL and P1.7/SDA are the serial I/O pins. These two pins meet the I<sup>2</sup>C specification concerning the input levels and output drive capability. Consequently, these pins have an open drain configuration. All four modes of the I<sup>2</sup>C bus can be used: - Master transmitter - Master receiver - Slave transmitter - Slave receiver The advantages of using the bit-level I<sup>2</sup>C hardware compared with a full software implementation are: - Higher bit rate - No critical software timing requirements - Less software overhead - More reliable data transfer The bit-level I<sup>2</sup>C hardware can perform the following functions: - Filtering the incoming serial data and clock signals. Glitches shorter than 4 XTAL periods are rejected. - Recognition of a START or STOP condition. - Generating an interrupt request after reception of a START condition. - Setting the Bus Busy flag when a START condition is detected. - Clearing the Bus Busy flag when a STOP condition is detected. - Recognition of a serial clock pulse on the SCL line. - Latching the serial data bit on the SDA line at every rising edge on the SCL line. - Stretching the LOW period of the serial clock SCL to synchronizer with external master devices. - Setting the Read Bit Finished (RBF) or Write Bit Finished (WBF) flag is an error free bit transfer has occurred. - Setting a Clock LOW-to-HIGH (CLH) flag when a leading edge is detected on the SCL line. - Generation of serial clock pulse on SCL in master mode. The following functions must be done with software: - Handling the I<sup>2</sup>C interrupt caused by a detected START condition. - Conversion of serial to parallel data when receiving. - Conversion of parallel to serial data when transmitting. - Comparing received slave address with own slave address. - Interpretation of acknowledge information. - Guarding the I<sup>2</sup>C status if the RBF and WBF flags indicate a not regular bit transfer. - Generating START/STOP conditions when in master mode. - Handling bus arbitration when in master mode. # **AN438** Figure 1. **AN438** # 2.2 Control and Status Registers Control of the I<sup>2</sup>C bus hardware is done via 3 Special Function Registers: SIINT This register contains the serial interrupt flag SI. S1BIT For read, this register contains the received bit SDI. For write, this register contains bit SDO to be transmitted. SISCS For read, this register contains status information. For write, this register is used as control register. ## 2.2.1 S1INT: I<sup>2</sup>C Interrupt Register - S1INT.7 is the Serial Interrupt request flag (SI). If the serial I/O is enabled (ENS = 1), then a START condition will be detected and the SI flag is set on the falling edge of the filtered SCL signal. Provided that EA (global enable) and ES1 (enable I<sup>2</sup>C interrupt) are set (in the interrupt enable IE register), SI generates an interrupt that will start the slave address receive routine. SI is cleared by accessing the S1BIT register or by writing '00H' to S1INT. SI cannot be set by software. After reception of a START condition, the LOW period of the SCL pulse is stretched, suspending serial transfer to allow the software to take appropriate action. This clock stretching is ended by accessing the S1BIT register. ## 2.2.2 S1BIT: Single Bit Data Register S1BIT.7 contains two physical latches: the Serial Data Output (SDO) latch for a write operation, and the filtered Serial Data Input (SDI) latch for a read operation. SDI data is latched on the rising edge of the filtered SCL pulse. S1BIT.7 accesses the same physical latches as S1SCS.7, but S1BIT.7 is not bit addressable. Reading or writing S1BIT register starts the next additional actions: - SI, CLH, RBF and WBF flags are cleared. - Stretching the LOW period of the SCL clock is finished. - Auto-clock pulse is started if enabled. The auto-lock is an active HIGH SCL pulse that starts 28 Xtal periods after an access to S1BIT. SCL remains high for 100 Xtal periods. If the SCL line is kept LOW by any device that wants to hold up the bus transfer, the auto-clock counter still runs for 20 Xtal periods to try to make SCL high and then go into a wait-state. This will result in a minimum SCL HIGH time of 80 Xtal periods (5 $\mu$ s at $f_{Xtal}=16$ MHz). The auto-clock signal will be inhibited if the SCO flag in the S1SCS register is set to '1'. SCL pulses must then be generated by software. In this situation, access to S1BIT may be used to clear the SI, CLH, RBF and WBF flags. A quick check on a successful bit transfer from/to SDO/SDI is carried out be testing only the RBF or WBF flag (see 2.2.3). ## 2.2.3 S1SCS: Control and Status Register S1SCS.7 represents two physical latches, the Serial Data Output (SDO) latch for write operations and the Serial Data Input (SDI) latch for read operations. S1SCS.7 accesses the same physical latches as S1BIT.7, but S1SCS.7 is bit addressable. However, a read or write operation of S1SCS.7 does not start an auto-lock pulse, with not finish clock stretching, and will not clear flags. S1SCS.6 represents two physical latches, the Serial Clock Output (SCO) latch for write operations and the Serial Clock Input (SCI) latch for read operations. The output of SCO is "OR-ed" with the auto-clock pulse. If SCO = '1' the auto-clock generation is disabled and its output is LOW. Internal clock stretching logic and external devices can then pull the SCL line LOW. If the auto-clock is not used, the SCL line has to be controlled by setting SCO = '1', waiting for CLH to become '1' and setting SCO = '0' after the specified SCL HIGH time. Data access should be done via \$1SCS.7. S1SCS.5 is the serial Clock LOW-to-HIGH transition flag (CLH). This flag is set by a rising edge of the filtered serial clock. CLH = '1' indicates that no devices are stretching SCL LOW, and since the last CLH reset, a new valid data bit has been latched in SDI. CLH can be cleared by writing '0' to S1SCS.5 or by a read or write operation to the S1BIT register. Clearing CLH also clears RBF and WBF. Writing a '1' to S1SCS.5 will not affect CLH. - S1SCS.4 is the Bus Busy flag (BB). BB is set or cleared by hardware only. If set, it indicates that a START condition has been detected on the I<sup>2</sup>C bus. A STOP condition clears the BB flag. - S1SCS.3 is the Read Bit Finished flag (RBF). If RBF = 1, it indicates that a serial bit has been received and latched into SDI successfully. If during a bit transfer RBF is '0', the cause is indicated as follows: | The SCL pulse is not finished and still HIGH. | |-------------------------------------------------------------------------------------------------------------| | A bus device is delaying the transfer by stretching the LOW level on the SCL line. | | A STOP-condition has been detected during<br>the bit transfer. This should be considered as<br>a bus-error. | | A START-condition has been detected during the bit transfer. This should be considered as a bus-error. | | | RBF can be cleared by clearing CLH or by a read or write operation to the S1BIT register. S1SCS.2 is the Write Bit Finished flag (WBF). If set, it indicates that a serial bit in SDO has been transmitted successfully. If during bit transfer WBF is '0', the following conditions may be the cause: | SCI = '1'<br>and<br>CLH = '1' | The SCL pulse is not finished and still HIGH. | |-------------------------------|-------------------------------------------------------------------------------------------------------| | CLH = '0' | A bus device is delaying the transfer by stretching the LOW level on the SCL line. | | BB = '0' | A STOP-condition has been detected during the bit transfer. This should be considered as a bus-error. | | SI = '1' | A START-condition has been detected during the bit transfer. This should be considered as | WBF can be cleared by clearing CLH or access to the S1BIT register. a bus-error. March 1991 Philips Semiconductors Application note # I<sup>2</sup>C routines for 8XC528 AN438 S1SCS.1 is the STRetch control flag (STR). STR can be set or cleared by software only. Setting STR enables the stretching of SCL LOW periods. Stretching will occur after a falling edge on the filtered serial clock. This allows synchronization with the SCL clock signal of an external master device. If STR is cleared, no stretching of the SCL LOW period will occur after the transfer of a serial bit. The LOW level on the SCL line is also stretched after a START condition is received, regardless of the STR contents. The stretching of the SCL LOW period is finished by a read or write operation of the S1BIT register. - S1SCS.0 is the ENable Serial I/O flag (ENS). ENS can be set or cleared by software only. ENS = '0' disables the serial I/O. The I/O signals P1.6/SCL and P1.7/SDA are determined by the port latches of P1.6 and P1.7 (open drain). If P1.6 and P1.7 are connected to an I²C bus, then the flags SDI, SCI, CLH, and BB still monitor the I²C bus status, but will not influence the I/O lines, nor will they request an interrupt. ENS = '1' enables the START detection and clock stretching logic. Note that the P1.6 and P1.7 latches and the SDO and SCO control flags must be set to '1' before ENS is set to avoid SCL and/or SDA to pull the lines LOW. Figure 2. Example of a Serial Transfer Philips Semiconductors Application note # I<sup>2</sup>C routines for 8XC528 AN438 # 3.0 I2C ROUTINES #### Introduction A set of routines is written for the I<sup>2</sup>C interface that supports multi-master and slave operation. The routines are placed in a library I2C DR.LIB. If I2C DR.LIB is linked to an application program, only the needed object modules are linked in the output The routines can be used as device driver for PL/M-51. C and 8051-assembly code. By using these routines the bit-level I2C interface is fully transparent for the user. The routines use the following 8xC528 resources: - Exclusive use of Register\_Bank\_1. Only R7 of this register bank contains static data (Own Slave Address). R0..R6 may be used by the application program when the I<sup>2</sup>C routine is finished. - 7 bytes DATA used for parameter passing. - 1 byte Bit-Addressable DATA for status flags. When using routines from this library DPH, DPL, PSW (except CY) and B are not altered. An n-bytes data buffer is used as destination or source buffer for the bytes to be received/transmitted and reside in DATA or IDATA memory space. The code is written to generate the highest transfer rate on the I<sup>2</sup>C bus. At f<sub>Xtal</sub> = 16MHz this will result in a bit rate of 87.5kbit/sec. The following software tools from BSO/Tasking are used for program development: - OM4142 Cross Assembler 8051 for DOS: V3.0b - OM4144 PL/M 8051 Compiler for DOS: V3.0a - OM4136 C8051 Compiler for DOS: V1.1a - OM4129 XRAY51 debugger: V1.4c #### 3.2 Functional Description When using these routines in a PL/M application program, they must be declared EXTERNAL. In this declaration the user can specify the type returned by each procedure. All procedures (except Init\_IIC and Dis\_IIC) can return a BIT or BYTE, depending on the chosen EXTERNAL declaration. The BIT or BYTE returned is '0' if the I2C was successful. If a BYTE is returned, the following check bits are available for the user: | BYTE.0 | An I <sup>2</sup> C error has been detected. | |--------|------------------------------------------------------------------------------------| | BYTE.1 | No ACK received. | | BYTE.2 | Arbitration lost. | | BYTE.3 | Time out error. This may be caused by an external device pulling SCL LOW. | | BYTE.4 | A bus error has occurred. This may be a spurious START/STOP during a bit transfer. | | BYTE.5 | No access to I <sup>2</sup> C bus. | | BYTE.6 | 0 | | BYTE.7 | 0 | | | | Note that typed procedures must be called using an expression. If the result of an I<sup>2</sup>C procedure is to be ignored, a dummy assignment must be done for a typed procedure. The examples in the following section assume that the procedures are called from a PL/M program. Examples will be given later how to use these routines with C and assembly application programs. #### Init\_IIC 3.2.1 #### Declaration Init IIC: PROCEDURE (Own\_Slave\_Address, Slave\_Sub\_Address) EXTERNAL: DECLARE (Own\_Slave\_Address, Slave\_Sub\_Address) BYTE; END: #### Description Init\_IIC must be called after RESET, before any procedure is called. The I<sup>2</sup>C interface and I<sup>2</sup>C interrupt will be enabled. The global enable interrupt flag, however, will not be affected. This should be done afterwards. Own\_Slave\_Address is passed to Init\_IIC for use as slave. Slave Sub Address is the pointer to a DATA buffer that is used for data transfer in slave mode. When used as master in a single master system, these parameters are not used. #### Example CALL Init\_IIC (54h,.Slave\_Data\_Buffer); ENABLE: /\* Enable Interrupts: EA=1 \*/ ## 3.2.2 Dis\_IIC ### Declaration Dis\_IIC: PROCEDURE EXTERNAL; #### Description Dis\_IIC will disable the I2C-interface and the I2C-interrupt. The I2C interface will still monitor the bus, but will not influence the SDA and SCL lines. #### Example CALL Dis\_IIC; # 3.2.3 IIC\_Test\_Device ## Declaration IIC Test Device: PROCEDURE (Slave\_Address) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address) BYTE; END; ### Description IIC\_Test Device just sends the slave address to the I2C bus. It can be used to check the presence of a device on the I2C bus. ## I<sup>2</sup>C Protocol S-SIvW-A-P : Device is present, IIC\_Error=0 S-SlvW-N-P : Device is not present, IIC\_Error=1 ## Example DECLARE IIC\_Error BIT; IIC\_Error=IIC\_Test\_Device(8Ch); IF (IIC\_Error) THEN "Device not acknowledging on slave address" **ELSE** "Device acknowledges on slave address" March 1991 168 Philips Semiconductors Application note # I<sup>2</sup>C routines for 8XC528 **AN438** ## 3.2.4 IIC\_Write #### Declaration IIC\_Write: PROCEDURE (Slave\_Address, Count, Source\_Ptr) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count, Source\_Ptr) BYTE; END: #### Description IIC\_Write is the most basic procedure to write a message to a slave device. #### I<sup>2</sup>C Protocol L =Count D1[0..L-1] BASED by Source\_Ptr S-SIvW-A-D1[0]-A....A-D1[L-1]-A-P #### Example DECLARE Data\_Buffer(4) BYTE; CALL IIC\_Write(02Ch, LENGTH(Data\_Buffer),.Data\_Buffer); ## 3.2.5 IIC\_Write\_Sub #### Declaration IIC\_Write\_Sub: PROCEDURE (Slave\_Address, Count, Source\_Ptr, Sub\_Address) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count, Source\_Ptr, Sub\_Address) BYTE; END; ## Description IIC\_Write\_Sub writes a message preceded by a sub-address to a slave device. #### I<sup>2</sup>C Protocol . =Count Sub =Sub\_Address D1[0..L-1] BASED by Source\_Ptr S-SIvW-A-Sub-A-D1[0]-A-D1[1]-A....A-D1[L-1]-A-P ## Example DECLARE Data\_Buffer(8) BYTE; CALL IIC\_Write\_Sub (48h,LENGTH(Data\_Buffer),.Data\_Buffer,2); ## 3.2.6 IIC\_Write\_Sub\_SWInc #### Declaration IIC\_Write\_Sub\_SWInc: PROCEDURE (Slave\_Address, Count, Source\_Ptr, Sub\_Address) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count, Source\_Ptr, Sub\_Address) BYTE; END: #### Description Some I<sup>2</sup>C devices addressed with a sub-address do not automatically increment the sub-address after reception of each byte. IIC\_Write\_Sub\_SWInc can be used for such devices the same way as IIC\_Write\_Sub is used. IIC\_Write\_Sub\_SWInc splits up the message in smaller messages and increments the sub-address itself. #### I<sup>2</sup>C Protocol =Count Sub =Sub\_Address D1[0..L-1] BASED by Source\_Ptr S-SIvW-A- (Sub+0) - A-D1[0] - A-P S-SIvW-A- (Sub+1) - A-D1[1] - A-P S-SIvW-A- (Sub+L-1)-A-D1[L-1]-A-P #### Example DECLARE Data Buffer(6) BYTE: CALL IIC\_Write\_Sub\_SWInc(80h,LENGTH (Data\_Buffer),.Data\_Buffer,2); ## 3.2.7 IIC\_Write\_Memory #### Declaration IIC\_Write\_Memory: PROCEDURE (Slave\_Address, Count, Source\_Ptr, Sub\_Address) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count, Source\_Ptr, Sub\_Address) BYTE; END; # Description I<sup>2</sup>C Non-Volatile Memory devices (such as PCF8582) need an additional delay after writing a byte to it. IIC\_Write\_Memory can be used to write to such devices the same way IIC\_Write\_Sub is used. IIC\_Write\_Memory splits up the message in smaller messages and increments the sub-address itself. After transmission of each message a delay of 40 milliseconds (f<sub>Xtal</sub> = 16 MHz) is inserted. # I<sup>2</sup>C Protocol L =Count Sub =Sub\_Address D1[0..L-1] BASED by Source\_Ptr S-SIvW-A- (Sub+0) - A-D1[0] - A-P Delay 40ms S-SIvW-A- (Sub+1) - A-D1[1] - A-P Delay 40ms S-SlvW-A- (Sub+L-1)-A-D1[L-1]-A-P Delay 40ms #### Example 169 DECLARE Data\_Buffer(10) BYTE; CALL IIC\_Write\_Memory(0A0h,LENGTH (Data\_Buffer),.Data\_Buffer,0F0h); March 1991 Philips Semiconductors Application note # I<sup>2</sup>C routines for 8XC528 **AN438** ## 3.2.8 IIC\_Write\_Sub\_Write #### Declaration IIC\_Write\_Sub\_Write: PROCEDURE (Slave\_Address, Count1, Source\_Ptr1, Sub\_Address, Count2, Source\_Ptr2) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count1, Source\_Ptr1, Sub\_Address, Count2, Source\_Ptr2) BYTE; END: END; ## Description IIC\_Write\_Sub\_Write writes 2 data blocks preceded by a sub-address in one message to a slave device. This procedure can be used for devices that need an extended addressing method, without the need to put all data into one large buffer. Such a device is the ECCT (I<sup>2</sup>C controlled teletext device; see example). #### I<sup>2</sup>C Protocol L =Count1 M =Count2 Sub =Sub\_Address D1[0..L-1] BASED by Source\_Ptr1 D2[0..M-1] BASED by Source Ptr2 S-SIvW-A-Sub-A-D1[0]-A-D1[1]-A-.... -A-D1[L-1]-A-D2[0]-A-D2[1]-A-.... -A-D2[M-1]-A-P #### Example PROCEDURE Write\_CCT\_Memory (Chapter, Row, Column, Data\_Buf, Data\_Count); DECLARE (Chapter, Row, Column, Data\_Buf, Data\_Count) BYTE; The extended address (CCT-Cursor) is formed by Chapter, Row and Column. These three bytes are written after the sub-address (=8) followed by the actual data that will be stored relative to the extended address. CALL IIC\_Write\_Sub\_Write (22h, 3, .Chapter, 8, Data\_Buf, Data\_Count); END Write\_CCT\_Memory; ## 3.2.9 IIC\_Write\_Sub\_Read #### Declaration ``` IIC_Write_Sub_Read: ``` PROCEDURE (Slave\_Address, Count1, Source\_Ptr1, Sub\_Address, Count2, Dest\_Ptr2) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count1, Source\_Ptr1, Sub\_Address, Count2, Dest\_Ptr2) BYTE; END: #### Description IIC\_Write\_Sub\_Read writes a data block preceded by a sub-address, generates an I<sup>2</sup>C restart condition, and reads a data block. This procedure can be used for devices that need an extended addressing method. Such a device is the ECCT. # I<sup>2</sup>C Protocol L =Count1 M =Count2 Sub =Sub\_Address D1[0..L-1] BASED by Source\_Ptr1 D2[0..M-1] BASED by Source\_Ptr2 S-SlvW-A-Sub-A-D1[0]-A-D1[1]-A-.... -A-D1[L-1]-A-S-SlvR-A-D2[0]-A-D2[1]-A-.... -A-D2[M-1]-N-P ## Example PROCEDURE Read\_CCT\_Memory (Chapter, Row, Column, Data\_Buf, Data\_Count); DECLARE (Chapter, Row, Column, Data\_Buf, Data\_Count) BYTE; The extended address (CCT-Cursor) is formed by Chapter, Row and Column. These three bytes are written after the sub-address (8). After that the actual data will be read relative to the extended address. CALL IIC\_Write\_Sub\_Write (22h, 3, .Chapter, 8, Data\_Buf, Data\_Count); END Read\_CCT\_Memory; **AN438** ## 3.2.10 IIC\_Write\_Com\_Write #### Declaration IIC\_Write\_Com\_Write: PROCEDURE (Slave\_Address, Count1, Source\_Ptr1, Count2, Source\_Ptr2) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count1, Source\_Ptr1, Count2, Source\_Ptr2) BYTE; END: ## Description IIC\_Write\_Com\_Write writes two data blocks from different data buffers in one message to a slave receiver. This procedure can be used for devices where the message consists of 2 different data blocks. Such devices are, for instance, LCD-drivers, where the first part of the message consists of addressing and control information, and the second part is the data string to be displayed. #### I<sup>2</sup>C Protocol L =Count1 M =Count2 D1[0..L-1] BASED by Source\_Ptr1 D2[0..M-1] BASED by Source\_Ptr2 S-SIvW-A-D1[0]-A-D1[1]-A-.... -A-D1[L-1]-A-D2[0]-A-D2[1]-A-.... -A-D2[M-1]-A-P ### Example DECLARE Control\_Buffer(2) BYTE; DECLARE Data\_Buffer(20) BYTE; CALL IIC\_Write\_Com\_Write(74h, LENGTH(Control\_Buffer), .Control\_Buffer, LENGTH(Data\_Buffer), .Data\_Buffer); ## 3.2.11 IIC\_Write\_Rep\_Write #### Declaration IIC\_Write\_Rep\_Write: PROCEDURE (Slave\_Address1, Count1, Source\_Ptr1, Slave\_Address2, Count2, Source\_Ptr2) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address1, Count1, Source\_Ptr1, Slave\_Address2, Count2, Source\_Ptr2) BYTE; FND: #### Description Two data strings are sent to separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. #### I2C Protocol L M =Count2 SIvW1 =Slave\_Address1 SIvW2 =Slave\_Address2 D1[0..L-1] BASED by Source\_Ptr1 D2[0..M-1] BASED by Source\_Ptr2 =Count1 S-SIvW-A-D1[0]-A-D1[1]-.... -A-D1[L-1]-A-S-SIvW-A-D2[0]-A-D2[1]-.... -A-D2[M-1]-A-P #### Example DECLARE Data\_Buffer\_1(10) BYTE; DECLARE Data\_Buffer\_2(4) BYTE; ..... CALL IIC\_Write\_Rep\_Write (48h, LENGTH(Data\_Buffer\_1), .Data\_Buffer\_1, 50h, LENGTH(Data\_Buffer\_2), .Data\_Buffer\_2); AN438 ## 3.2.12 IIC Write Rep Read #### Declaration IIC Write Rep Read: PROCEDURE (Slave\_Address1, Count1, Source\_Ptr1, Slave\_Address2, Count2, Dest\_Ptr2) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address1, Count1, Source\_Ptr1, Slave Address2, Count2, Dest Ptr2) BYTE: END: ## Description A data string is sent and received to/from two separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. ## I<sup>2</sup>C Protocol М =Count1 =Count2 SlvW1 =Slave\_Address1 SlvW2 D1[0..L-1] =Slave\_Address2 BASED by Source Ptr1 D2[0..M-1] BASED by Dest\_Ptr2 S-SIvW-A-D1[0]-A-D1[1]-.... -A-D1[L-1]-A-S-SIvR-A-D2[0]-A-D2[1]-.... -A-D2[M-1]-N-P #### Example DECLARE Data\_Buffer\_1(10) BYTE; DECLARE Data\_Buffer\_2(4) BYTE; CALL IIC\_Write\_Rep\_Read (48h, LENGTH(Data Buffer 1). .Data\_Buffer\_1, 57h, LENGTH(Data\_Buffer\_2), .Data\_Buffer\_2); # 3.2.13 IIC Read # Declaration IIC Read: PROCEDURE (Slave\_Address, Count, Dest\_Ptr) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count, Dest\_Ptr) BYTE; END; ### Description IIC\_Read is the most basic procedure to read a message from a slave device. # I<sup>2</sup>C Protocol М =Count D2[0..M-1] BASED by Dest\_Ptr S-SIvR-A-D2[0]-A-D2[1]-A.....A-D2[M-1]-N-P # Example DECLARE Data\_Buffer(4) BYTE; CALL IIC\_Read (0B5, LENGTH(Data\_Buffer), .Data\_Buffer); ## 3.2.14 IIC\_Read\_Status #### Declaration IIC\_Read Status: PROCEDURE (Slave\_Address, Dest\_Ptr) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Dest\_Ptr) BYTE: END: ## Description Several I<sup>2</sup>C devices can send a one byte status-word via the bus. IIC\_Read\_Status can be used for this purpose. IIC\_Read\_Status works the same way as IIC\_Read but the user does not have to pass a count parameter. ## I<sup>2</sup>C Protocol Status BASED by Dest Ptr S-SlvR-A-Status-N-P ## Example DECLARE Status\_Byte BYTE; CALL IIC\_Read\_Status (84h, .Status\_Byte); # 3.2.15 IIC Read Sub ## Declaration IIC Read Sub: PROCEDURE (Slave Address, Count, Dest Ptr. Sub Address) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address, Count, Dest\_Ptr, Sub\_Address) BYTE: END; # Description IIC\_Read\_Sub reads a message from a slave device, preceded by a write of the sub-address. Between writing the sub-address and reading the message, an I<sup>2</sup>C restart condition is generated without releasing the bus. This prevents other masters from accessing the slave device in between and overwriting the sub-address. ## I<sup>2</sup>C Protocol M =Count Sub =Sub\_Address D2[0..M-1] BASED by Dest\_Ptr S-SIvW-A-Sub-A-S-SIvR-D2[0]-A-D2[1]-A.....A-D2[M-1]-N-P #### Example DECLARE Data\_Buffer(5) BYTE: CALL IIC\_Read\_Sub (0A3h, LENGTH(Data\_Buffer), .Data\_Buffer, 2); Application note # I<sup>2</sup>C routines for 8XC528 **AN438** ## 3.2.16 IIC\_Read\_Rep\_Read ## Declaration IIC\_Read\_Rep\_Read: PROCEDURE (Slave\_Address1, Count1, Dest\_Ptr1, Slave\_Address2, Count2, Dest\_Ptr2) [BITIBYTE] EXTERNAL; DECLARE (Slave\_Address1, Count1, Dest\_Ptr1, Slave\_Address2, Count2, Dest\_Ptr2) BYTE; END: # Description Two data strings are read from separate slave device, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. ## I<sup>2</sup>C Protocol L =Count1 M =Count2 SIvW1 =Slave\_Address1 SIvW2 =Slave\_Address2 D1[0..L-1] BASED by Dest\_Ptr1 D2[0..M-1] BASED by Dest\_Ptr2 S-SIvR-A-D1[0]-A-D1[1]-..... -A-D1[L-1]-N-S-SIvR-A-D2[0]-A-D2[1]-..... -A-D2[M-1]-N-P ## Example DECLARE Data\_Buffer\_1(10) BYTE; DECLARE Data\_Buffer\_2(4) BYTE; CALL IIC\_Read\_Rep\_Read (49h, LENGTH(Data\_Buffer\_1), .Data\_Buffer\_1, 51h, LENGTH(Data\_Buffer\_2), .Data\_Buffer\_2); ## 3.2.17 IIC\_Read\_Rep\_Write #### Declaration ## Description A data string is received and sent from/to two separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. ### I<sup>2</sup>C Protocol L =Count1 M =Count2 SIvW1 =Slave\_Address1 SIvW2 =Slave\_Address2 D1[0..L-1] BASED by Dest\_Ptr1 D2[0..M-1] BASED by Source\_Ptr2 S-SivR-A-D1[0]-A-D1[1]-..... -A-D1[L-1]-N-S-SivW-A-D2[0]-A-D2[1]-..... -A-D2[M-1]-A-P ## Example DECLARE Data\_Buffer\_1(10) BYTE; DECLARE Data\_Buffer\_2(4) BYTE; CALL IIC\_Read\_Rep\_Write(49h, LENGTH(Data\_Buffer\_1), .Data\_Buffer\_1, 58h, LENGTH(Data\_Buffer\_2), .Data\_Buffer\_2); Philips Semiconductors Application note # I<sup>2</sup>C routines for 8XC528 AN438 ## 3.2.18 Slave Mode Routines There are two ways for the I2C interface to enter the slave-mode: - After an I<sup>2</sup>C interrupt the software must enter the slave-receiver mode to receive the slave address. This address will then be compared with its own address. If there is a match either slave-transmitter or slave-receiver mode will be entered. If no match occurs, the interrupted program will be continued. - During transmission of a slave-address in master-mode, arbitration is lost to another master. The interface must then switch to slave-receiver mode to check if this other master wants to address the 8xC528 interface. The slave-mode protocol is very application dependent. In this note the basic slave-receive and slave-transmit routines are given and should be considered as examples. The user may for instance send NO\_ACK after receiving a number of bytes to signal to the master-transmitter that a data buffer is full. A description of the code will be given later. Slave parameters are given with the Init\_IIC procedure. The passed parameters are the own-slave-address and a source/destination-pointer to a data buffer. The slave-routine will be suspended at the following conditions: - Interrupts with higher priority. Slave-routine will be resumed again after interrupt is handled. - If a NO ACKNOWLEDGE is received form a master-receiver. - If a STOP condition is detected from a master transmitter. Constraints for user software. - The user must control the global enable (EA) bit. - The user must control the priority level of the I<sup>2</sup>C interrupt. If the slave routine is interrupted by a higher priority interrupt, the SCL line will be stretched to postpone bus transfer until the higher interrupt is finished. ## 3.3 The Slave Routine: SLAVE.ASM The listing of the slave routine can be seen on page 175. The routine is written in such a way that stretching of SCL is minimized. Application code can be inserted in this routine and this will increase stretching time. The routine has 2 entry points. Entry via MST\_ENTRY happens when an arbitration error has occurred when transmitting a slave address in master mode. Auto-clock generation will be disabled and SCL stretching enabled. The byte will be continued to be received and can later be compared with the own slave address. The second entry point is via an interrupt when a START condition is detected. At \_PIPOA the context of the interrupted program is stored. Next Auto-clock generation is disabled and SCL stretching enabled. Reception of the slave address can now begin by calling RCV\_SL\_BY. When the received slave-address is compared with the own-slave-address the R/W-bit is ignored. If there is no match between the 2 addresses, a negative ACK bit is sent and the slave routine is left via EXIT. If there was a match the R/W bit is checked to enter the slave-receiver or slave-transmitter mode. The slave-transmitter mode starts at NXT\_TRX. After getting the byte from the data buffer via BUF\_POINT and initializing the bit counter BIT\_CNT the transmission loop is entered. A bit is written via access to S1BIT because this will automatically reset the CLH and WBF status flags, and also SCL stretching. Now WBF must be tested until the transmission is successful. When WBF becomes true, SCL will be stretched again. When 8 bits are sent, the SDA line is released and RBF is tested until the ACK bit is received. The ACK bit is read by reading SDI instead of S1BIT to maintain SCL stretching. If ACK was false, no more bytes have to be sent and the routine is left. If another byte has to be transmitted, BUF\_POINT is updated and transmission will continue. The slave-receiver mode starts at RCV\_SLAVE. A byte is received by calling RCV\_SL\_BY. This routine will clear the CY-flag when a STOP condition has been received. This means that the master will send no more bytes to this slave and the slave routine will be left. When no STOP condition was detected, the received byte will be stored @BUF\_POINT and an ACK bit will be sent. After this, a new byte can be received. When calling RCV\_SL\_BY the bit counter BIT\_CNT will be initialized and the SCL stretching stopped by a dummy access to S1BIT. In the receive loop both BB and RBF will be checked. When BB is cleared, a STOP condition is detected and the routine will be left with CY=0. The first 7 bits are received via S1BIT because this will release stretching. The 8th bit is accessed via SDI because stretching must be maintained. If the slave routine is left via EXIT, the STR bit is cleared (to disable stretching on SCL edges when the 8xC528 is not addressed as slave) and a dummy access to S1BIT is done to finish current SCL stretching. If the slave routine was entered via an interrupt the previous context is restored. **AN438** ``` TSW-ASM51 V3.0b Serial #00052252 Slave interrupt routine PAGE OBJ LINE SOURCE LOC 1 $TITLE(Slave interrupt routine) 2 SDEBUG 3 $NOLIST 6 ; ; This routine handles I2C interrupts. 8 ;8xC528 I2C interface enters in slave mode. 9 ;After testing R/W bit, 8xC528 will go in slave-transmit or 10 ;slave-receive mode. 11 ;Source or destination buffer for data uses pointer SLAVE_SUB_ADDRESS 12 ;Slave routine will use register bank 01 13 ; 15 ; Interrupt entry point 16 17 CSEG AT 53H 18 0053: 020000 LJMP __PIPOA ; Vector to interrupt handler 19 20 ; .,********************* 22 23 I2C DRIVER SEGMENT CODE INBLOCK 24 RSEG I2C_DRIVER 2.5 PUBLIC MST_ENTRY 2.6 2.7 EXTRN DATA (SLAVE_SUB_ADDRESS) 28 EXTRN BIT (ARB_LOST) 29 REG END BUF_POINT SET RO 30 REG END OWN_SLAVE SET R7 31 BIT_CNT SET R2 REG END 32 33 ******************* 34 35 0000: C0E0 36 __PIPOA:PUSH ACC ; Push CPU status on stack 0002: COD0 37 PUSH PSW 0004: 75D008 38 MOV PSW, #08H ;Select registerbank 01 39 40 ;******************** 41 ;Check slave address 0007: 43D842 44 ORL S1SCS, #01000010B ; Disable SCL generation and enable SCL ;stretching stretching R 45 000A: 1142 ACALL RCV_SL_BY ; Receive slave address, on exit SCL is : stretched 000C: A2E0 46 PROC: MOV C, ACC.0 ;Store R/W bit in F0 000E; 92D5 MOV FO,C 47 0010: 6F 48 XRL A,OWN_SLAVE ; Compare received slave address ``` **AN438** ``` TSW-ASM51 V3.0b Serial #00052252 Slave interrupt routine PAGE LOC OBJ LINE SOURCE 0011: C2E0 49 CLR ACC.0 ; Ignore R/W bit 0013: 7050 50 JNZ NO_MATCH ;Leave slave-routine if there is no match 0015: C3 51 CLR C :Send ACK 0016: 115C 52 ACALL SEND_ACK 0018: A800 MOV BUF_POINT, SLAVE_SUB_ADDRESS ;Get buffer pointer 53 001A: A2D5 54 MOV C,F0 ;Restore R/W bit 001C: 5019 55 JNC RCV_SLAVE ;Test R/W bit 56 57 58 ;Slave transmitter mode ************ 60 61 62 001E: E6 63 NXT_TRX:MOV A,@BUF_POINT;Get byte to send 001F: 7A08 64 MOV BIT_CNT, #08 ; Init bit counter 65 0021: NXT_TRX_BIT: 66 0021: F5D9 67 MOV S1BIT, A ;Trx bit and stretch after transmission 0023: 23 68 RL A ;Prepare next bit to send 0024: 30DAFD 69 JNB WBF,$ ;Test if bit is sent 0027: DAF8 70 DJNZ BIT_CNT, NXT_TRX_BIT ; Test if all bits are sent 71 0029: D2DF 72 SETB SDO ; Release SDA line for NO_ACK/ACK reception 002B: E5D9 73 MOV A, S1BIT ;Stop stretching 002D: 30DBFD 74 JNB RBF,$ ;Test if ACK bit is received 0030: A2DF 75 MOV C,SDI ; Read bit, SCL remains stretched 0032: 4040 76 JC EXIT ;NO_ACK received. Exit slave routine 0034: 08 77 INC BUF_POINT ; ACK received. Update pointer for next byte to ;send 78 0035: 80E7 SJMP NXT_TRX 79 ************************* 80 81 ;Slave receiver mode ************************ 83 0037: 84 RCV_SLAVE: ;Entry in slave-receiver mode 0037: 1142 85 R ACALL RCV_SL_BY ; Receive byte 0039: 5039 ; If STOP is detected, then exit 86 JNC EXIT 003B: F6 87 MOV @BUF_POINT, A ; Store received byte 003C: C3 88 CLR C ;Send ACK 003D: 115C 89 CALL SEND_ACK 003F: 08 90 INC BUF_POINT ;Update pointer 0040: 80F5 91 SJMP RCV_SLAVE ;Receive next byte 92 93 ``` # **AN438** ``` TSW-ASM51 V3.0b Serial #00052252 Slave interrupt routine PAGE OBJ LINE SOURCE LOC 95 ; Receive byte routine 96 ;On exit, received byte in accu ;On exit CY=0 if STOP is detected 0042: 99 RCV_SL_BY: 0042: 7A08 MOV BIT_CNT, #08 100 ;Disable stretching from START or previous ACK MOV A, S1BIT 0044: E5D9 101 CLR A 0046: E4 102 0047: 103 RCV_BIT: JNB BB, STOP_RCV ; Test if STOP-condition is received 0047: 30DC10 104 JNB RBF, RCV BIT ; Wait till received bit is valid 004A: 30DBFA 105 CJNE BIT_CNT, #01, ASSEM_BIT ; Check if last bit is to be received 004D: BA0105 106 107 MOV C,SDI ;Get last bit without stopping stretching 0050: A2DF 108 RLC A 0052: 33 109 ;No STOP detected 0053: D3 110 SETB C 0054: 22 111 RET 112 113 ASSEM_BIT: 0055: ; Receive bit; release RBF, CLH and SCL stretching 0055: 45D9 ORL A, S1BIT 114 0057: 23 115 RL A DJNZ BIT_CNT, RCV_BIT 0058: DAED 116 117 005A: 118 STOP_RCV: CLR C :STOP detected 005A: C3 119 005B: 22 120 121 ******************** 122 ; Send ACK/NO_ACK. Value of ACK in Carry 124 005C: 125 SEND_ACK: 005C: 13 126 RRC A MOV S1BIT, A ;Carry to SDA line 005D: F5D9 127 ;Test if ACK/NO_ACK is sent 005F: 30DAFD 128 JNB WBF,$ 0062: D3DF 129 SETB SDO ;Release SDA line 0064: 22 130 RET 131 132 ; No match between received slave-address and own-slave-address ******************** 134 0065: 135 NO_MATCH: ;Send NO_ACK 0065: D3 SETB C 136 ACALL SEND_ACK 0066: 115C R 137 0068: 800A 138 SJMP EXIT ``` AN438 ``` TSW-ASM51 V3.0b Serial #00052252 Slave interrupt routine PAGE LOC OBJ LINE SOURCE 141 ; Entry point when an arbitration-lost condition is detected in ; master-mode. 142 006A: 143 MST_ENTRY: 006A: 23 144 RL A ;Restore slave address sofar 006B: C2E0 145 CLR ACC.0 006D: 43D842 146 ORL S1SCS, #01000010B ; Disable SCL generation and enable SCL ;strectching 0070: 1147 147 ACALL RCV_BIT ;Proceed with receiving rest of slave address 0072: 8098 148 SJMP PROC 149 150 ;************************ ;Exit from interrupt routine ;********************************** 154 0074: C2D9 155 EXIT: CLR STR ;Disable stretching on next falling SCL edges 0076: E5D9 156 MOV A, S1BIT ;Stop current SCL stretching 0078: 30001 157 JNB ARB_LOST, EX_SL 007B: 22 158 RET ;Exit when entered from master mode 007C: D0D0 159 EX_SL: POP PSW ;Restore old CPU status 007E: D0E0 160 POP ACC 0080: 32 161 RETI 162 0081: 163 END ``` Application note ### I<sup>2</sup>C routines for 8XC528 AN438 #### 4.0 EXAMPLES #### 4.1 Introduction Some examples are given how to use the I<sup>2</sup>C routines in an application program. Examples are given for assembly, PL/M and C program. The program displays time from the PCF8583P clock/calendar/RAM on an LCD display driven by the PCF8577. The example can be executed on the OM4151 I<sup>2</sup>C evaluation board. #### 4.2 Using the Routines with Assembly Sources The listing of the example program is shown on page 180. The most important aspect when using the I<sup>2</sup>C routines is preparing the input parameters before the sub-routine call. When, for example, the IIC\_Write routine must be called, the parameters must be called in the following order: MOV\_IIC\_READ\_BYTE,#SLAVE\_ADR MOV\_IIC\_READ\_BYTE+1,#COUNT\_1 MOV\_IIC\_READ\_BYTE+2,#SOURCE\_PTR\_1 CALL\_IIC\_READ Note that the order of defining the parameters is the same as in a PL/M-call. An easier way to call the routines is making a macro that includes the initializing of the parameters. The example program makes use of macros. IIC\_Read is then called in the following way: %IIC\_Read(Slave\_Adr,Count\_1,Source\_Ptr\_1); Note that in the listing the contents of the macro are shown, instead of the call. The macro must be written as follows: %\* DEFINE (IIC\_Read(SLAVE\_ADR,COUNT\_1,SOURCE\_PTR\_1)) (MOV\_IIC\_READ\_BYTE,#%SLAVE\_ADR MOV\_IIC\_READ\_BYTE+1,#%COUNT\_1 MOV\_IIC\_READ\_BYTE+2,#%SOURCE\_PTR\_1 LCALL\_IIC\_READ) Macros for the I<sup>2</sup>C CALLs are found in I2C.MAC. This file should be included in all modules making use of the macros. One of the modules should also include the variable definitions needed by the I<sup>2</sup>C routines. These are found in file VAR\_DEF.ASM. If the program consists of more than 1 module, then these modules should also include EXT\_VAR.ASM. This file contains the EXTRN- definitions of the I<sup>2</sup>C routines. When and I<sup>2</sup>C routine is called, the accumulator contains status information and the CY-bit is set if an error has occurred. The contents of the accumulator are the same as the returned byte when using PL/M. AN438 ``` TSW-ASM51 V3.0b Serial #00052252 Assembly example program PAGE LOC OBJ LINE SOURCE 1 $TITLE(Assembly example program) $DEBUG 3 ; Hours and minutes will be displayed on LCD display ;Dot between hours and minutes will blink 7 ; Include I2C var. definitions # 1 "C:\USER\VAR_DEF.ASM" Я 74 # 8 "DEMO_ASM.ASM" 8 $ ;Include I2C macro's 9 # 1 "C:\USER\I2C.MAC" 35 # 9 "DEMO_ASM.ASM" 00A2 10 CLOCK_ADR EQU 0A2h ;Address of PCF8583 0001 11 CL_SUB_ADR EQU 01h ;Sub address for reading time 0074 LCD_ADR 12 EOU 74h ;Address of PCF8577 13 14 RAMVAR SEGMENT DATA ;Segment for variables USER SEGMENT DATA ;Segment for application ;program 16 ____ 17 RSEC RAMVAR 0000: 18 R STACK: DS 10 ;Stack area 000A: 19 TIME_BUFFER:DS 4 ;Buffer for I2C strings 000E: 20 LCD_BUFFER: DS 5 22 CSEG AT 00 0000: 020000 23 R LJMP APL_START 24 25 ____ 26 RSEG USER 27 0000: R 28 APL_START: 0000: 900073 R 29 MOV DPTR, #LCD_TAB ;Pointer to segment table 0003: 7581FF R 30 MOV SP, #STACK-1 ;Initialize stack 0006: 750E00 R 31 MOV LCD_BUFFER, #00 ;Control word for LCD driver 32 0009: 750022 33 MOV _Init_IIC_Byte ,#22h 000C: 75010A R 34 MOV _Init_IIC_Byte+1, #TIME_BUFFER 000F: 120000 R 35 LCALL _Init_IIC 36 ;Initialize I2C interface 0012: E4 37 CLR A ;Prepare buffer for clock int. 0013: F50A R 38 MOV TIME_BUFFER, A 0015: F50B R 39 MOV TIME_BUFFER+1, A 40 0017: 7500A2 R MOV _IIC_Write_Byte ,#CLOCK_ADR 41 001A: 750102 R 42 MOV _IIC_Write_Byte+1,#2 001D: 75020A MOV _IIC_Write_Byte+2, #TIME_BUFFER R 43 0020: 120000 R 44 LCALL _IIC_Write ``` March 1991 AN438 | TSW-A | SM51 V3.0 | b Se | rial | #00052252 Assembly example program | PAGE | 2 | |-------|-----------|------|------|---------------------------------------------------------|-----------|------| | LOC | OBJ | L | INE | SOURCE | | | | | | | 45 | ;Initialize clock | | | | | | | 46 | | | | | 0023: | | | 47 | REPEAT: | | | | 0023: | 7500A2 | R | 48 | MOV _IIC_Read_Sub_Byte ,#CLOCK_ADR | | | | 0026: | 750104 | R | 49 | MOV _IIC_Read_Sub_Byte+1,#4 | | | | 0029: | 75020A | R | 50 | MOV _IIC_Read_Sub_Byte+2, #TIME_BUFFER | | | | 002C: | 750301 | R | 51 | MOV _IIC_Read_Sub_Byte+3, #CL_SUB_ADR | | | | 002F: | 120000 | R | 52 | LCALL _IIC_Read_Sub | | | | | | | 53 | ;Read time | | | | | | | 54 | | | | | | | | 55 | ;Time has been read. Order: hundreds of sec's, sec's, m | in's and | hr's | | 0032: | E50D | R | 56 | MOV A, TIME_BUFFER+3 ; Mask of hour c | ounter | | | 0034: | 543F | | 57 | ANL A, #3Fh | | | | 0036: | F50D | R | 58 | MOV TIME_BUFFER+3, A | | | | | | | 59 | | | | | 0038: | 120054 | R | 60 | CALL CONVERT ;Convert time of | ata to LC | D | | | | | | ;segment data | | | | | | | 61 | | | | | | | | 62 | ;Check if dot has to be switched on | | | | 003B: | 431101 | R | 63 | ORL LCD_BUFFER+3,#01h | | | | | | | 64 | ;If 1sb of seconds is '0', then switch on dp | | | | 003E: | E50B | R | 65 | MOV A, TIME_BUFFER+1 ;Get seconds | | | | 0040: | 13 | | 66 | RRC A | | | | 0041: | 4003 | | 67 | JC PROCEED | | | | 0043: | 430F01 | R | 68 | ORL LCD_BUFFER+1,#01 ;Switch on dp | | | | | | | 69 | | | | | | | | 70 | ;Display new time | | | | 0046: | | | 71 | PROCEED: | | | | 0046: | 750074 | R | 72 | MOV _IIC_Write_Byte ,#LCD_ADR | | | | 0049: | 750105 | R | 73 | MOV _IIC_Write_Byte+1,#5 | | | | 004C: | 75020E | R | 74 | MOV _IIC_Write_Byte+2, #LCD_BUFFER | | | | 004F: | 120000 | R | 75 | LCALL _IIC_Write | | | | | | | 76 | | | | | 0052: | 80CF | | 77 | SJMP REPEAT ;Read new time | : | | | | | | 78 | | | | | | | | 79 | | | | | | | | 80 | ;CONVERT converts BCD data of time to segment data | | | | 0054: | 780F | R | 81 | CONVERT: MOV RO, #LCD_BUFFER+1 ;R0 is pointer | | | | 0056: | E50D | R | 82 | MOV A, TIME_BUFFER+3 ;Get hours | | | | 0058: | C4 | | 83 | SWAP A ;Swap nibbles | | | | 0059: | 12006D | R | 84 | CALL LCD_DATA ;Convert 10's | of hours | | | 005C: | E50D | R | 85 | MOV A, TIME_BUFFER+3 | | | | 005E: | 12006D | R | 86 | CALL LCD_DATA ;Convert hours | | | | 0061: | E50C | R | 87 | MOV A, TIME_BUFFER+2 ;Get minutes | | | | 0063 | : C4 | | 88 | SWAP A | | | | 0064: | : 12006D | R | 89 | CALL LCD_DATA ;Convert 10's | of minute | s | | 0067: | : E50C | R | 90 | MOV A, TIME_BUFFER+2 | | | | 0069: | 12006D | R | 91 | CALL LCD_DATA ;Convert minut | es | | | | | | | | | | **AN438** ``` TSW-ASM51 V3.0b Serial #00052252 Assembly example program PAGE 3 LINE SOURCE LOC OBJ 006C: 22 92 RET 93 94 ;LCD_DATA gets data from segment table and stores it in LCD_BUFFER 006D: LCD DATA: 95 006D: 540F 96 ANL A, #0FH ; Mask off LS-nibble 006F: 93 97 MOVC A, @A+DPTR ;Get segment data 0070: F6 98 MOV @RO, A ; Save segment data 0071: 08 99 INC RO 0072: 22 100 RET 101 102 ;Conversion table for LCD 0073: 103 LCD_TAB: 0073: FC60DA 104 DB OFCH, 60H, ODAH ; '0', '1', '2' 0076: F266B6 105 DB 0F2H,66H,0B6H ; '3', '4', '5' 0079: 3EE0FE 106 DB 3EH, 0EOH, 0FEH ; '6', '7', '8' 007C: E6 107 DB OE6H ; '9' 108 ; 007D: 109 END ``` ### 4.3 Using the Routines with PL/M-51 Sources The following listing shows the listing of the clock program in PL/M-51. The procedures are untyped. The routines are used the same way as in the examples of chapter 3.2. ``` $OPTIMIZE(4) $DEBUG $CODE /* Hours and minutes will be displayed on LCD display Dots between hours and minutes will blink */ Demo plm: Do; /* External declarations */ Init_IIC: Procedure(Own_Adr,Slave_Ptr) External; Declare (Own_Adr, Slave_Ptr) Byte Main; End Init_IIC; IIC_Write: Procedure(Sl_Adr,Nr_Bytes,Source_Ptr) External; Declare (Sl_Adr, Nr_Bytes, Source_Ptr) Byte Main; End IIC_Write; IIC_Read_Sub: Procedure(S1_Adr,Nr_Bytes,Dest_Ptr,Sub_Adr) External; Declare(Sl_Adr, Nr_Bytes, Dest_Ptr, Sub_Adr) Byte Main; End IIC_Read_Sub; ``` ``` Clock: Do; /* Variable and constant declarations */ Declare LCD_TAB(*) Byte Constant (0FCh,60H,0DAH,0F2H,66H, OB6H, 3EH, OEOH, OFEH, OE6H); Declare Time_Buffer(4) Byte Main; Declare LCD_Buffer(5) Byte Main; Declare Tab_Point Word Main; Declare (LCD_Point, Time_Point) Byte Main; Declare Segment Based LCD_Point Byte Main; Declare Time Based Time_Point Byte Main; Declare Tab Value Based Tab_Point Byte Constant; Declare clock_Adr Literally '0A2h'; Declare LCD_Adr Literally '74h'; Declare C1_Sub_Adr Literally '01h'; Call Init_IIC(22h, .Time_Buffer); LCD_Buffer(0)=0; /* LCD control word */ Time_Buffer(0)=0; Time_Buffer(1)=0; Call IIC_Write(Clock_Adr, 2, .Time_Buffer); /* Initialize clock */ Do While LCD_Buffer(0)=0; /* Program loop */ Call IIC_Read_Sub(Clock_Adr, 4, .Time_Buffer, Cl_Sub_Adr); /* Get time */ LCD_Point=.LCD_Buffer+1; /* Initialize pointers */ Time_point=.Time_Buffer(3); Tab_Point=.LCD_Tab(0)+SHR(Time,4); /* 10-HR's */ Segment=Tab_Value; LCD_Point=LCD_Point+1; Tab_Point=.LCD_Tab(0)+(Time AND 0FH); /* HR's */ Segment=Tab_Value; Time_Point=Time_Point-1; LCD Point=LCD_Point+1; Tab_Point=.LCD_Tab+SHR(Time,4); /* 10-MIN's */ Segment=(Tab_Value OR 01H); /* dp */ LCD_Point=LCD_Point+1; Tab_Point=.LCD_Tab+(Time AND 0FH); /* MIN's */ Segment=Tab_Value; Time_Point=.Time_Buffer(1)+1; /*Check sec's for blinking */ LCD_Point=.LCD_Buffer+1; If (Time AND 01H)>0 then Segment=(Segment OR 01H); Call IIC_Write(LCD_Adr,5,.LCD_Buffer); /* Display time */ End; End Clock: End Demo_plm; ``` **AN438** #### 4.4 Using the Routines with C Sources An example of a C program using the I<sup>2</sup>C routines follows. Function prototypes are found in header file "i2c.h". In this example the function prototypes are written in such a way that not value is returned by the function. If the STATUS byte is needed, the header file may be changed to return a byte. Note that the function calls are written in upper-case. This is due to the fact that the used version of the assembler/linker is case sensitive. ``` #include <C:\USER\i2c.h> rom char LCD_Tab[] = {0xFC, 0x60, 0xDA, 0xF2, 0x66, 0xB6, 0x3E, } 0xE0,0xFE,0xE6); void main() { #define Clock_Adr 0xA2 #define LCD_Adr 0 \times 74 #define C1_Sub_Adr 0 \times 01 rom char * Tab_Ptr; data char Time_Buffer[4]; data char * Time_Ptr; data char LCD_Buffer[5]; data char * LCD_Ptr; INIT_IIC(0x22,&Time_Buffer); LCD_Buffer[0]=0; /* LCD control word */ Time_Buffer[0]=0; Time_Buffer[1]=0; IIC_WRITE(Clock_Adr,2,&Time_Buffer); /* Initialize clock */ while (1) /* Program loop */ { IIC_READ_SUB(Clock_Adr, 4, &Time_Buffer, C1_Sub_Adr); /* Get time */ LCD_Ptr = &LCD_Buffer[1]; /* Initialize pointers */ Time_Ptr = &Time_Buffer[3]; Tab_Ptr = (LCD_Tab+(*Time_Ptr >> 4)); /* 10-HR's */ *(LCD_Ptr++) = *Tab_Ptr; Tab_Ptr = (LCD_Tab+(*(Time_Ptr--) & 0x0F)); /* HR's */ *(LCD_Ptr++) = *Tab_Ptr; Tab_Ptr = (LCD_Tab+(*Time_Ptr >> 4)); /* 10-MIN's */ *(LCD_Ptr++) = (*Tab_Ptr | 0x01); /* dp */ Tab_Ptr = (LCD_Tab+(*Time_Ptr & 0x0F)); /* MIN's */ *LCD_Ptr = *Tab_Ptr; Time_Ptr = &Time_Buffer[1]; /* Check sec's for blinking */ LCD_Ptr = &LCD_Buffer[1]; if ((*Time_Ptr & 0x01)>0) *LCD_Ptr = (*LCD_Ptr | 0x01); IIC_WRITE(LCD_Adr,5,&LCD_Buffer); /* Display time */ } ``` **AN438** ### 5.0 CONTENTS OF DISK A disk contains the following 3 directories: #### 1: \USER This director contains the files that may be used in the user program. I2C\_DR.LIB Library with I<sup>2</sup>C routines. I2C.H Header file for C applications. IZC.MAC Macro's for the I<sup>2</sup>C routine calls in assembly programs. VAR\_DEF.ASM Include file with variable definitions for assembly programs. EXT\_VAR.ASM Include file with external definitions for assembly programs. LIB.BAT Example batch file to create I2C\_DR.LIB. ASM.BAT Example batch file to assemble source modules for library. #### 2: \EXAMPLE This directory contains the source files of the examples described in chapter 4.0. DEMO\_ASM.\* Assembly example. DEMO\_PLM.\* PL/M example. HEAD\_51.SRC Example of environment file for PL/M example. DEMO\_C.\* C example. CSTART.ASM Example of environment file for C example. #### 3: \SOURCE This directory contains the source files of the modules in the library. March 1991 185 **AN444** ### Author: Don Sherman, Sunnyvale The P82B715 I<sup>2</sup>C Buffer was designed to extend the range of the local I<sup>2</sup>C bus out to 50 Meters. This application note describes the results of testing the buffer on several different types of cables to determine the maximum operating distances possible. The results are summarized in a table for easy reference. The I<sup>2</sup>C bus was originally conceived as a convenient 2 wire communication method between Integrated Circuits located within a common chassis, such as inside a TV set or inside a VCR. The serial protocol contains an address, or identifying code, for each type of device and additional internal addresses, if needed within the addressed device. Each device has its own decoding circuitry to allow it to recognize its own unique address or identifying code. To communicate, a device watches the bus activity and jumps in when it sees a stop. Once a Master gets control of the bus, it sends the address of the particular device with which it wants to communicate. Communication will then transpire between the Master and the Slave device. The existence of many types of ICs which have built-in I2C interface capabilities makes system design almost as easy as drawing a block diagram. Real-time clocks, RAM, A/D converters, EEPROMs, Microcontrollers. Keyboard encoders, LCD display drivers, and many other I2C supported chips all communicate over two wires rather than needing 16 Address lines, 8 data lines and Address decoders along with handshake signals, which more conventional designs would require to be routed all over the Printed Circuit board. Now, with the introduction of the I<sup>2</sup>C buffer chip, it is easy to branch out beyond the single chassis mode and use this convenient local area network to tie together whole systems without the need to convert from the "internal" I<sup>2</sup>C protocol to an external communication medium such as RS-232 and then RS-485. By using the new Philips I<sup>2</sup>C buffer, the external systems' components can be accessed as easily as the internal I<sup>2</sup>C connected components. The P82B715 is an 8 pin IC which contains 2 identical amplifier sections to allow for the current amplification and buffering of both the SDA and the SCL signals on the I<sup>2</sup>C bus. Each section in the P82B715 contains a bipolar times 10 current amplifier which senses the direction of current flow through an internal 30 ohm series resistor in the I<sup>2</sup>C line. The P82B715 then boosts the current, while keeping the voltage gain at unity, and continues to maintain the voltage drop direction across the resistor. This configuration results in different waveforms as the P82B715 starts to do its job. If the driving source has a strong current sink capability, then it will start to drive the buffered I2C line immediately through the 30 ohm resistor. A microsecond later the P82B715's amplified pull down current kicks in and pulls the line down even harder. If the driving IC is only capable of the I2C specified 3 milliamp pull down current, the buffered bus will fall a little and then just wait at that voltage level for the propagation delay of the amplifier to finally turn on and bring the buffered bus down to a logic low. Thus, there will always be some form of a step in the falling edge of the buffered output waveform. see Figure 1. A weak source will have a step (plateau) up near 4 volts and a strong source, such as the Philips Semiconductors 87C751 microcontroller, will have the step occur below 2 volts. The position of the step will be determined by the current sink capability of the I2C bus driver versus the value of the pull-up resistor which is used on the buffered $I^{2}C$ bus, $Vstep = 5V - (Isink \times Rbuf)$ . For example: $Vstep = 5V - (3mA \times .165 \text{ k ohms})$ = 5 - .495 = 4.5Volts; another example: $Vstep = 5V - (20mA \times .165 \text{ k ohms}) = 5 - 3.3$ Running the I<sup>2</sup>C signals over long distances poses several problems. The I2C SDA and SCL lines are monitored by all of the ICs connected on the I<sup>2</sup>C bus. These ICs each have their own circuitry to decipher the information on the bus. In normal operation, a Start occurs when there is a high to low transition on the SDA line while SCL is high. Obviously, if any external noise is coupled into the SDA line, it could be mistakenly perceived as a Start. Because of this, some form of shielding will be preferred to protect the two I2C signals from external noise sources. During the transmission of data there are signals which are active on both SDA and SCL. If these normal signals are cross-coupled, then data can be corrupted. Thus, although the standard telephone twisted pair cable is the most commonly available built in cable, it is not recommended for long I2C runs. This cable maximizes crosstalk, due to the twisted pair configuration and, since there is no shielding, is very vulnerable to adjacent wire telephone signal coupling and to any stray external electromagnetic interference. This effect can be somewhat reduced by running a signal wire and a grounded wire as adjacent pairs. Long distance cables present capacitive loading which must be overcome with the driver chips. The limiting factor is the amount of pull-up current which is available to charge the line capacitance. With the simple resistor pull-up recommended by I<sup>2</sup>C standards, three milliamps is available for charging this line capacitance. The rise time of the signal will increase linearly with the increase in capacitive loading and the specified maximum capacitive loading is only 400 Pico Farads for guaranteed 100kHz communication rates. The P82B715 current buffer allows for 30 milliamps of pull-up current, with a resulting maximum capacitive loading of 4,000 Pico Farads (4 Nano Farads). The I2C hardware inputs look at the I2C signals and act when those signals pass through the active linear region at about 1.2 to 1.4 volts, and are detected as digital levels. Thus, there is a delay between when an output transistor turns off and when the rising signal is detected as a logic one at the receiver. This time depends on the value of the pull-up resistor, the perceived capacitance at the transmitting end, the delay through the cable, and finally the delay through the receiver's amplifier to its output stage. The maximum allowable time is limited by the characteristic that the I2C master provides the clock signal which must travel down the cable and be received by the slave. This slave must act on the clock signal and produce data information which is sent back to the master with an additional set of delays. Upon reception the data must be put in its proper place before the master starts its next clock signal, or an error will occur. Different types of cable were tested and the results are shown in Table 1. Keep in mind that the results are based on cable runs in a low electrical noise environment. If reliable operation is desired in a high electrical noise environment, shielded cable must be used. For "short" runs, flat cable with every other conductor grounded, seems to provide a good, low capacitance medium for I2C transmission, otherwise, the shielded audio cable seemed to provide the best price/performance. Note that for long runs, it is desirable to have a separate power supply at each end of the cable, and the shield or ground wire will provide a common reference between the two supplies. The voltage drop due to the resistance of the wire usually is the limiting factor for very long runs of cable where the power to the remote system must also come through the cable. Table 1 shows the results of testing with longer and longer cable lengths until failures were detected. The values in the table represent the maximum cable lengths which still provided error free code from a modified version of the Ping-pong program which is listed in Application Note AN430. ### Using the P82B715 I<sup>2</sup>C extender on long cables **AN444** Figure 1. P82B715 Output Waveform on Long Cable Table 1. Test Results with P82B715 Over Long Cables | CABLE TYPE | Ohms/m | pF/m | Total Length | Total Ohms | Total Cap. | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|--------------|------------|------------| | Belden 8723 45 Ohm Audio<br>2 each 2—24AWG wire stranded Beldfoil Aluminum-<br>polyester shielded with common drain wire<br>SDA & ground on one pair; SCL & ground on other pair | .049 | 115 | 305M (1000') | 11.5 | 48.2nF | | Belden 8723 45 Ohm Audio<br>using 1 shielded pair, SDA on Red, SCL on Black | .049 | 115 | 330M (1100') | 12.7 | 53nF | | RG-174/U 50 Ohm Video Cable<br>SDA and grounded shield in one cable<br>SCL and grounded shield in one cable | .318 | 101 | 150M (500') | 47.7 | 15.2nF | | "Telephone Cable"<br>22&24 AWG Solid Copper Twisted Pair, Level 3 LAN &<br>Medium Speed Data<br>SDA and ground in one twisted pair<br>SCL and ground in one twisted pair | .0286 | 66 | 95M (310') | 2.7 | 6.4nF | | Flat "Ribbon" Cable, every other conductor grounded | .20 | 52 | 400M (1320') | 80.5 | 21nF | In all of the tests, the power supply voltage was 4.5 volts. The ground for the remote test fixture was through the long cable. Since 4.5 volts is the recommended minimum voltage for both the 87C751 and the P82B715, it was not possible to operate the remote unit on power supplied through the long cable, since any ohmic drop would place the ICs out of their specified range. However, it is necessary to connect the grounds between the two units for the best noise immunity. The P82B715 is designed to drive a 4 nF capacitive load at 100kHz. However, the actual total capacitances of the long cables which worked were substantially greater than this. The loading did effect the software driven hardware part of the 87C751. To achieve a true 100kHz data rate, it was necessary to shorten the '751 Timer values for the I<sup>2</sup>C drivers. This resulted in an asymmetrical waveform, but did achieve a 10 microsecond period (100kHz). This asymmetry in duty cycle can be easily seen in the Figure 1 waveform. The test with the Belden 8723 Audio Cable worked if one of the shielded pair was connected to a signal and the other was connected to ground or +5volts. When both wires were connected in parallel as signal wires, the capacitance to ground doubled and the test failed. Also note that the adjacent wire mutual inductive coupling of the SDA and SCL signals did not seem to cause any problems even out to 1000 feet. This indicated that possibly the Belden 9452 45 ohm beldfoil shielded audio cable with a single set of twisted pair wires would be a good candidate to also try. Flat ribbon cable provided a good compromise between shielding and reasonable capacitance. It is possible to increase the shielding effect by using flat cable with an etched copper foil layer on the back side of the cable. Noise can be induced into the cable by folding it back over itself for mutual induction effects, and also by operating a noise source close to the cable. A transformer type of soldering iron and florescent light transformers seemed to be good noise sources. The P82B715 can drive multiple P82B715 remote units. The line should have some form of pull-up resistor at each driver. If only two drivers are used, as shown in Figure 2, the load should be split between the two drivers. For example, if the pull-up current is to be 30 milliamps and the voltage is 5 volts. the pull-up resistance should be: 5V/.030 amps = 165 ohms. This should be implemented by placing a 330 ohm resistor at each end of the cable so that the parallel resistance is 165 ohms and each end of the line is terminated. Remembering that the current gain can be as low as 8 and that most runs will not be to the maximum possible distance, lower values of pull-up current can **AN444** be used with the appropriate modifications to the above equations. For larger fan-out with fixed locations, the load resistance should also be evenly divided so that the parallel combination of all of the pull-up resistors will provide the desired D.C. pull-up current. If some of the remote units will be pluggable, it will be necessary to divide the pull-up load to accommodate all of the possible combinations of possible fanout. Figure 3 shows an example of driving up to 30 remote, pluggable peripherals. On the 3 milliamp side of the P82B715 a complete I<sup>2</sup>C system may exist. In Figure 3, a local I<sup>2</sup>C network cluster could be joined to other local network clusters through the P82B715 buffered bus so that hundreds of I<sup>2</sup>C devices could potentially be interconnected. The ease of connecting I<sup>2</sup>C clusters into a complete LAN opens the door for many new uses of components which have an I<sup>2</sup>C bus connection. Now an electronic instrument can have access to remote keyboards and remote sensors by using the I<sup>2</sup>C bus. The instrument's output can easily be shown on multiple remote displays all connected with the I<sup>2</sup>C bus. Multiple instruments can also pass data back and forth over the I<sup>2</sup>C bus. Thus, we see that the I<sup>2</sup>C bus can become an effective and inexpensive Local Area Network by using the P82B715 I<sup>2</sup>C bus extender. #### THE TEST SETUP These tests were run on two identical test boards which each use a Philips Semiconductors 87C751 microcontroller that drives the I<sup>2</sup>C buffer which has a 330 ohm pull-up resistor. The schematic is shown in Figure 4. The software is a modified version of the "Ping-Pong" program which is described in the Philips Semiconductors Application Note, AN430, "Using the 8XC751/752 in Multimaster applications". This program sends a number down the I<sup>2</sup>C line and, when received, the receiving unit becomes a master and increments the number and sends it back to the first unit where it is checked and then the process repeats itself. The software has extensive error detection capability and monitors for corruption of data, false starts, over run of data, stuck lines and about anything else which might indicate a problem. If any errors did occur, a software counter was incremented. In this setup, the counter was stopped at Hex 07F to prevent wrap around and the contents of the counter are displayed on a bank of 8 LEDs. The MSB of the counter register was used as an indicator that the unit was working. The MSB LED flashes at about a 1 Hz rate when the unit is operating normally. When a cable length was reached which was too long, the MSB LED would stop flashing and the counter would rapidly fill up and stop with all 7 LEDs on (LED on indicates a logic "1" in this application). #### THE TEST HARDWARE A general purpose test rig was designed so that future needs of a general I<sup>2</sup>C platform could also be met. All of the port pins on the '751 were used. The inputs to the system were a toggle switch with a pull-up resistor connected to P0.2 (because this pin is Open Drain) and an octal DIP switch connected to port 1 (the internal pull ups of the port were used, so no external pull-up resistors were needed). The output is displayed through an octal buffer connected to port 3. A logical "1" on the pin will light up the LED. The I2C signals, SDA and SCL, are connected to the I<sup>2</sup>C buffer chip and the outputs of the buffer are pulled up by 330 ohm resistors. The parallel combination of the buffered transmitting end pull-up and the receiving end pull-up resistors is 330/2 ohms, which results in a pull-up load current of 30 milliamps. This current from the two pull-up resistors must be sunk by the single driving transistor of the acting sender. The effective loading seen by the '751 is the I2C buffer's load divided by 10. Thus, the '751's I2C outputs will sink 3 milliamps when driving the I2C buffer which is sinking 30 milliamps on the buffered bus. The software monitor routine allows the user to monitor any internal '751 RAM location and display the contents on the LEDs. The monitor routine also allows the user to modify the contents of any RAM location including SFR space. The Ping-Pong program needed the first 8 locations in RAM, so the stack pointer for this application was changed from the default location of 07H to location 09H. This starts the stack at 0AH. To read the contents of RAM, set the DIP switches to the desired RAM address. The toggle switch is set to a "1". Pressing the Reset switch causes the microprocessor to reset and then enter the monitor program where the program then waits until the toggle switch is changed. Upon closing the toggle switch (a "1" to "0" transition) the program loads the DIP switch selection into R0 of bank 1 (RAM location 08H). The program then loads the contents of the RAM location pointed to by R0 (bank 1) and copies it into port 3, where it is displayed on the 8 LEDs. Thus, the Address is seen by looking at the DIP switches and the contents pointed to are displayed on the LEDs. Note that this indirect Address latch location (R0,bank 1) would have been the normal beginning of the stack, had it not been changed. The contents of an internal RAM location can also be modified with this program. First, set the DIP switches to the desired Address and set the toggle switch to "0". Reset the processor and then set the toggle switch to "1". This transfers the address to R0 (bank 1). Next, load the desired new data, which is to be stored in RAM, into the DIP switches, and then set the toggle switch to "0". At this time the LEDs will now show the Address of RAM and the DIP switches show what was written into the selected RAM location. To verify that the data was actually written into the RAM, follow the read RAM sequence. Although this may seem to be a bit cumbersome, it is a workable way to see what is happening inside of the '751. Remember that it is necessary to re-enter the monitor program, or at least to duplicate the read RAM of R0 (bank 1) and output to port 3, to see the latest version of the contents of the RAM location. Since this experiment only looked at the contents of one RAM location, the above method was easy to use and the display always showed the current status of the desired RAM location because it is updated often by the software. # Using the P82B715 $I^2C$ extender on long cables **AN444** Figure 2. P82B715 Driving Long Line Figure 3. Large Fan-Out Configuration for P82B715 Note that $V_{CC}$ is 5 volts for these values of load resistors. If a different voltage is desired, the calculations are as follows: $$R_{master} = \frac{V_{CC}}{15mA}$$ example: $R_{master} = \frac{5V}{15mA} = 0.33k = 330\Omega$ The pluggable units would be calculated as follows: Parallel combination of $R_{slave} = R_{master}$ $R_{slave} = R_{master} \times Fan out$ example: $R_{slave} = 330\Omega \times 30 = 9900\Omega = 10k$ **AN444** Figure 4. Schematic ``` **************** Multimaster Code for 83C751/83C752 4/14/1992 MODIFIED BY DON SHERMAN 5-21-92 ;; is used to show where original code was modified _************************************ ; This code was written to accompany an application note. The I2C routines ; are intended to be demonstrative and transportable into different ; application scenarios, and were NOT optimized for speed and/or memory ; utilization. ; Yoram Arbel $TITLE(83C751 Multi Master I2C Routines) $DATE(4/14/1992) SMOD751 ;; NEED TO USE $MOD752 FOR 752 EMULATOR ES NEED ENABLE FOR EMULATOR ::EI2 EOU $DEBUG ************************ 8XC751 MULTIMASTER I2C COMMUNICATIONS ROUTINES Symbols and RAM definitions ; Symbols (masks) for I2CFG bits. BTIR EQU 10h ; TIRUN bit. BMRO EQU 40h ; MASTRO bit. ; Symbols (masks) for I2CON bits. BCXA EOU 80h ; CXA bit. BIDLE EQU 40h ; IDLE bit. ; CDR bit. EOU 20h BCDR ; CARL bit. EQU 10h BCARL EQU 08h ; CSTR bit. BCSTR 04h BCSTP EQU ; CSTP bit. 02h ; XSTR bit. BXSTR EQU BXSTP 01h EQU : XSTP bit. ; Note: ; Specific bits of the I2CON register are set by writing into this register a ; combination of the masks defined above using the MOV command. ; The SETB command should not be used with I2CON, as it is implemented by ; reading the contents of the register, setting the appropriate bit and ; writing it back into the register. As the functionality of the Read and ; Write portions of the I2CON register is different, using SETB may cause ; unwanted results. ; Message transaction status indications in MSGSTAT: SGO EQU 10h ; Started Slave message processing. SRCVD EQU 11h ; as a slave, received a new message SRLNG 12h EQU ; received as slave a message which is too : long for the buffer STXED 13h ; as slave, completed message transmission. SRERR EQU 14h ; bus error detected when operating as a slave. ; Started Master message processing. 20h MRCVED ; As Master, received complete message from ; slave. MTXED EQU 22h ; As Master, completed successful message ; transmission (slave acknowledged all data ; bvtes). MTXNAK 23h ; As Master, truncated message since slave did ; not acknowledge a data byte. ``` **AN444** ``` ; AS Master, did not receive an acknowledgement MTXNOSLV EQU ; for the specified slave address. TIMOUT EQU 30h ; TIMERI Timed out. NOTSTR EQU 32h ; Master did not recognize Start. ; RAM locations used by I2C interrupt service routines. MASCMD DATA 20h SUBADD BIT MASCMD.0 RPSTRT BIT MASCMD.1 SETMRQ BIT MASCMD.2 DSEG AT 24h MSGSTAT: DS 1 ; I2C communications status. MYADDR: ; Address of this I2C node. DESTADRW: DS 1 ; Destination address + R/W (for Master). DESSUBAD: DS 1 ; Destination subaddress. MASTCNT: 1 ; Number of data bytes in message (Master, ; send or receive). TITOCNT: DS 1 ; Timer I bus watchdog timeouts counter. StackSave: DS 1 ; SP save location (used when returning from ; bus recovery routine). MasBuf: 4 ; Master receive/transmit buffer, 8 bytes. SRcvBuf: DS ; Slave receive buffer, 8 bytes. STxBuf: DS ; Slave transmit buffer, 8 bytes. RBufLen ; The length of SRcvBuf APPLICATION output pins and RAM definitions ; Outputs used by the application: ;;TogLED BIT P1.0 ; Toggling output pin, to confirm ; that the ping-pong game proceeds fine. :: ErrLED BIT P1.1 ; Error indication. ;;OnLED BIT P1.3 ; Application RAM APPFLAGS DATA 21h TRQFLAG BIT APPFLAGS.0 ; Flag for monitoring I2C transmission success. SETTLAG BIT APPFLAGS.1 FAILCNT: DS TOGCNT: DS 1 ; Toggle counter. ``` **AN444** ``` Program Start CSEG ; Reset and interrupt vectors. ;;JUMP TO MONITOR AJMP DONMON ; Reset vector at address 0. ; A timer I timeout usually indicates a 'hung' bus. ORG 1Bh ; Timer I (I2C timeout) interrupt. SETB ; Go to Interrupt Service Routine. AJMP TIISR I2C Interrupt Service Routine ; Notes on the interrupt mechanism: ; Other interrupts are enabled during this ISR upon return from XRETI. ; Limitations imposed on other ISR's: ; - Should not be long (close to 1000 clock cycles). A long ISR will cause the I2C bus to 'hang", and a TIMERI interrupt to occur. ; - Other interrupts either do not use the same mechanism for allowing further interrupts, or if they do - disable TIMERI interrupt beforehand. ; The 751 hardware allows only one level of interrupts. We simulate an ; additional level by software: by performing a RETI instruction (at location ; XRETI) the interrupt-in-progress flip-flop is cleared, and other interrupts ; are enabled. The second level of interrupt is a must in our implementation, ; enabling timeout interrupts to occur during "stuck" wait loops in the I2C ; interrupt service routine. ORG 23h ; Disable I2C interrupt. I2CISR: CLR ET2 ACALL XRETI ; Allow other interrupts to occur. PUSH PSW PUSH ACC MOV A.RO PUSH ACC MOV A,R1 PUSH ACC VOM A,R2 PUSH ACC MOV StackSave, SP CLR TIRUN TIRUN SETB JΒ STP, NoGo JNB MASTER, GoSlave MOV MSGSTAT, #MGO JB STR, GoMaster NoGo: MOV MSGSTAT, #NOTSTR AJMP Dismiss ; Not a valid Start. XRETI: RETI ``` June 1993 194 **AN444** ``` Main Transmit and Receive Routines ************************* SLAVE CODE - GET THE ADDRESS MOV GoSlave: MSGSTAT, #SGO AddrRcv: ACALL ClsRcv8 TNB DRDY, SMsgEnd ; Must be some strange Start or Stop ; before the address byte was completed. ; Not a valid address. STstRW: MOV C,ACC.0 ; Save R/W~ bit in carry. CT.R ACC.0 ; Clear that bit, leaving "raw" address GoIdle ; If it is a General Address ; - ignore it. ; NOTE: ; One may insert here a different ; treatment for general calls, if ; these are relevant. JC SlvTx ; It's a Read - (requesting slave ; transmit). ; It is a Write (slave should receive the message). Check if message is for us SRcv2: CJNE A, MYADDR, Goldle ; If not my address - ignore the ; message. MOV R1, #SRcvBuf ; Set receive buffer address. MOV R2, #RbufLen+1 SJMP SRcv3 SRcvSto: MOV @R1,A ; Store the byte Inc R1 ; Step address. SRcv3: ACAT<sub>I</sub>T AckRcv8 JNB DRDY, SRCvEnd ; Exit loop -end reception. DJNZ R2, SRCvSto ; Go to store byte if buffer not full. ; Too many bytes received - do not acknowledge. MSGSTAT, #SRLNG ; Notify main that (as slave) we ; have received too long a message. ACALL SLnRCvdR ; Handle new data - slave event routine. SJMP GoIdle ; Received a byte, but not DRDY - check if a legitimate message end. SRcvEnd: CJNE R0, #7, SRCVErr ; If bit count not 7, it was not ; a Start or a Stop. ; Received a complete message MOV MSGSTAT, #SRCVD ; Calculate number of bytes received MOV A,R1 CLR C SUBB A, #SRcvBuf ; number of bytes in ACC ACALL SRCvdR ; Handle new data - slave event routine. SJMP SMsgEnd ; It is a Read message, check if for us. SlvTx: NOP STx2 · CINE A, MYADDR, Goldle ; Not for us. I2DAT,#0 ; Acknowledge the address. JNB ATN,$ ; Wait for attention flag. ``` **AN444** ``` DRDY, SMsgEnd ; Exception - unexpected Start JNE ; or Stop before the Ack got out. ; Start address of transmit buffer. MOV R1, #STxBuf ; Get byte from buffer STxlp: MOV A, @R1 INC ACALL XmByte DRDY, SMsgEnd ; Byte Tx not completed. JNB RDAT, STxlp ; Byte acknowledge, proceed trans. ; Master Nak'ed for msg end. I2CON, #BCDR+BIDLE MOV MOV MSGSTAT, #STXED ACALL STXedR ; Slave transmitted event routine. AJMP Dismiss SRcvErr: MOV MSGSTAT, #SRERR ; Flag bus/protocol error ; Slave error event routine. ACALL SRETTR SJMP SMsgEnd MSGSTAT, #SRERR ; Flag bus/protocol error StxErr: MOV ACALI SRErrR MASTER, SMsgEnd2 SMsqEnd: STR, GoSlave ; If it was a Start, be Slave JB SMsgEnd2: AJMP Dismiss ; End of Slave message processing GoIdle: AJMP Dismiss GoMaster: ; Send address & R/W~ byte MOV R1, #MasBuf ; Master buffer address MOV R2, MASTCNT ; # of bytes, to send or rcv MOV A, DESTADRW ; Destination address (including ; R/W~ byte). ; Branch if subaddress is needed. SUBADD, GoMas2 JB XmAddr ACALL JNB DRDY, GM2 JNB ARL, GM3 ; Arbitration loss while transmitting GM2: AJMP AdTxArl ; the address. ; No Ack for address transmission. RDAT, Noslave GM3: JB ACC.0, MRcv ; Check R/W~ bit JB AJMP ; Handling subaddress case: NOP ; Subaddress needed. Address in ACC. GoMas2: ACC.0 ; Force a Write bit with address. CLR ACALL XmAddr DRDY, GM4 TNB JNB ARL, GM5 GM4: AJMP AdTxArl ; Arbitration loss while transmitting ; the address. JB RDAT, Noslave ; No Ack for address transmission. GM5: MOV A, DESSUBAD ACALL XmByte ; Transmit subaddress. JNB DRDY, SMsgEnd2 ; Arbitration loss (by Start or Stop) JΒ ARL, SMsgEnd2 ; Arbitration loss occurred. JB RDAT, NoAck ; Subaddress transmission was not ack'ed. A, DESTADRW ; Reload ACC with address. MOV JNB ACC.0, MTx ; It's a Write, so proceed ; by sending the data. ; Read message, needs rp. Start and add. retransmit. ``` **AN444** ``` MOV I2CON, #BCDR+BXSTR ; Send Repeated Start. JNB ATN,$ I2CON, #BCDR ; Clear useless DRDY while preparing MOV ; for Repeated Start. ; expecting an STR. ATN,$ TNP JNB ARL, GM6 AJMP MArlEnd ; oops - lost arbitration. : Retransmit address, this time with the GM6: XmAddr ACALT. ; Read bit set. JNB DRDY, GM7 JNB ARL, GM8 GM7: AJMP AdTxArl ; Arbitration loss while transmitting ; the address. GM8: JB RDAT, Noslave ; No Ack - the slave disappeared. SJMP MRcv ; Proceed receiving slave's data. Master transmits the data. ; A Write message. MTx: NOP MTxLoop: MOV A, @R1 ; Get byte from buffer. INC R1 ; Step the address. ACALL XmByte JNB DRDY, SMsgEnd2 ; Arbitration loss (by Start or Stop) JB ARL, SMsgEnd2 ; Arbitration loss. RDAT, NoAck JB DJNZ R2,MTxLoop ; Loop if more bytes to send. MOV MSGSTAT, #MTXED ; Report completion of buffer ; transmission. SJMP MTxStop NoSlave: MOV MSGSTAT, #MTXNOSLV SJMP MTxStop MOV MSGSTAT, #MTXNAK NoAck: SJMP MTxStop ; Master receive - a Read frame ClaRcv8 ACALT. MRCV: : Receive a byte. SJMP MRcv2 MRcvLoop: ACALL AckRcv8 MRcv2: JNB DRDY, MArl ; Other's Start or Stop. MOV @R1,A ; Store received byte. TNC R1 : Advance address. DJNZ R2, MRcvLoop ; Received the desired number of bytes - send Nack. MOV I2DAT, #80h JNB ATN,$ JNB DRDY, MArl MOV MSGSTAT, #MRCVED SJMP MTxStop ; Go to send Stop or Repeated Start. ; Conclude this Master message: ; Send Stop, or a Repeated Start JNB MTxStop: RPSTRT, MTxStop2 ; Check if Repeated Start needed ; Around if not RPSTRT. VOM I2CON, #BCDR+BXSTR ; Send Repeated Start. SJMP MTxStop3 MOV MTxStop2: C, SETMRQ ; Set new Master Request if demanded MOV MASTRQ, C ; by SETMRQ bit of MASCMD. I2CON, #BCDR+BXSTP ; Request the HW to send a Stop. MOV MTxStop3: JNB ATN, S ; Wait for Attention VOM I2CON, #BCDR ; Clear the useless DRDY, generated ; by SCL going high in preparation ; for the Stop or Repeated Start. TNR ATN,$ ; Wait for ARL, STP or STR. JB ARL, MarlEnd ; Lost arbitration trying to send ; Stop or a ReStart. ``` **AN444** ``` ; Master is done with this message. May proceed with new messages, if any, ACALL ; Master Event Routine. May Prepare MastNext ; the pointers and data for the ; next Master message. JNB MASTRO, MMsgEnd ; Go end service routine if MASTRO ; does not indicate that the master ; should continue (was set according ; to SETMRQ bit, or by MastNext). JNB STR, MMsqEnd ; Return from the ISR, unless Start ; (avoid danger if we do not return: ; if there was a Stop, the watchdog ; is inactive until next Start). AJMP GoMaster ; Loop for another Master message MMsaEnd: ; End of Master messages, SJMP Dismiss ; Terminate mastership due to an arbitration loss: MArl: JNB STR, MAr12 ; If lost arbitration due to other ; Master's Start, go be a slave. A.TMP GoSlave Marl2: AJMP Dismiss ; Switch from Master to Slave due to arbitration loss after completing ; transmission of a message. The MASTRQ bit was cleared trying to write a ; Stop, and we need to set it again on order to retry transmission when the ; bus gets free again. MArlEnd: SETB MASTRO ; Set Master Request - which will get ; into effect when we are done as a ; slave. ACALL MORERR ;;INCREASE ERROR COUNT AJMP MArl ; Handling arbitration loss while transmitting an address STR, MArl AdTxArl: JB ; Non-synchronous Start or Stop. STP, MArl ; Switch from Master to Slave due to arbitration loss while transmitting ; an address - complete receiving the address transmitted by the new Master. CINE R0,#0,AdTxAr12 ; Arl on last bit of address ; (R0 is 0 on exit from XmAddr). DEC ; The 1sb sent, in which arl occurred ; must have been 1. By decrementing ; A we get the address that won. SJMP Adara AdTxArl2: RR Α ; Realign partially Tx'ed ACC MOV R1,A ; and save itin R1 MOV A,RO ; Pointer for lookup table MOV DPTR, #MaskTable MOVC A,@A+DPTR ANL A,R1 ; Set address bits to be received, ; and the bit on which we lost ; arbitration to 0 ; Now we are ready to receive the rest ; of the address. ``` **AN444** ``` MOV I2CON, #BCXA+BCARL ; Clear flags and release the clock. ACALL RBit3 ; Complete the address using reception ; subroutine. JB DRDY, Adar3 ; Around if received address OK AJMP SMsgEnd ; Unexpected Start or Stop - end ; as a slave. AdAr3: AJMP STstRW ; Proceed to check the address ; as a slave. MaskTable: DB Offh, 7Eh, 3Eh, 1Eh, 0Eh, 06h, 02h, 00h, ; Offh is dummy ; End I2C Interrupt Service Routine: Dismiss: ACALL 12CDONE MOV I2CON, #BCARL+BCSTP+BCDR+BCXA+BIDLE CLR TIRUN POP ACC MOV R2,A POP ACC MOV R1,A POP ACC MOV RO,A POP ACC POP PSW SETB EI2 ; Return from I2C interrupt Service Routine Byte Transmit and Receive Subroutines XmAddr: Transmit Address and R/W~ XmByte: Transmit a byte MOV XmAddr: I2DAT, A ; Send first bit, clears DRDY. MOV I2CON, #BCARL+BCSTR+BCSTP ; Clear status, release SCL. MOV RO.#8 ; Set RO as bit counter SJMP XmBit2 XmByte: MOV R0,#8 XmBit: MOV I2DAT, A ; Send the first bit. XmBit2: ; Get next bit. RL JNB ATN,$ ; Wait for bit sent. JNB DRDY, XmBex ; Should be data ready. DJNZ R0,XmBit ; Repeat until all bits sent. MOV I2CON, #BCDR+BCXA ; Switch to receive mode. JNB ATN.S ; Wait for acknowledge bit. ; flag cleared. XmBex: RET ; Byte receive routines. ; ClsRcv8 clears the status register (from Start condition) and then receives a byte. ; AckRcv8 Sends an acknowledge, and then receives a new byte. If a Start or Stop is encountered immediately after the ack, AckRcv8 returns with 7 in R0. ClaRcv8 clears the transmit active state and releases clock (from the acknowledge). A contains the received byte upon return. RO is being used as a bit counter. ClsRcv8: I2CON, #BCARL+BCSTR+BCSTP+BCXA ;Clear status register. JNR ATN,$ JNB DRDY, RCVex SJMP Rcv8 ``` **AN444** ``` I2DAT,#0 ; Send Ack (low) AckRcv8: MOV ATN,$ ; Bus exception - exit. JNB DRDY, RCVerr ; clear status, release clock MOV I2CON, #BCDR+BCXA ClaRcv8: ;from writing the Ack. JNB ATN,$ R0,#7 ; Set bit counter for the first seven Rcv8: MOV ; bits. ; Init received byte to 0. CLR A, I2DAT ; Get bit, clear ATN. RRit. ORL RBit2: RL ; Shift data. ; Wait for next bit. ATN, $ JINB ; Exit if not a data bit (could be Start/ DRDY, RCVex ; Stop, or bus/protocol error) RBit3: DJNZ R0,RBit ; Repeat until 7 bits are in. ; Get last bit, don't clear ATN. MOV C, RDAT ; Form full data byte. RLC RCVex: R0,#9 ; Return non legitimate bit count RCVerr: Timer I Interrupt Service Routine I2C us Timeout ; In addition to reporting the timeout in MSGSTAT, we update a failure ; counter, TITOCNT. This allows different types of timeout handling by the ; main program. TIISR: MASTRQ ; "Manual" reset. CLR I2CON, #BXSTP MOV I2CON, #BCXA+BCDR+BCARL+BCSTR+BCSTP MOV TT1: MOV MSGSTAT, #TIMOUT ; Status Flag for Main. ACALL MORERR ;; INC TITOCHT ACALL RECOVER TI4: SETB ; Clear TI interrupt flag. CLRTI ACALL XRETI ; Clear interrupt pending flag (in ; order to re-enable interrupts). SP, StackSave ; Realign stack pointer, re-doing ; possible stack changes during ; the I2C interrupt service routine. ; TimerI interrupts in other ISR's ; were not allowed ! ; Go back to the I2C service routine, A.TMP Dismiss ; in order to return to the (main) ; program interrupted. Bus recovery attempt subroutine RECOVER: CLR EΑ CLR MASTRO ; "Manual" reset. I2CON, #BCXA+BIDLE+BCDR+BCARL+BCSTR+BCSTP MOV CLR SLAVEN ; Non I2C TimerI mode TIRUN ; Fire up TimerI. When it overflows, it SETB ; will cause I2C interface hardware reset. MOV R1,#0ffh DLY5: NOP NOP NOP D/INZ R1, DLY5 CLR TIRUN SETB CLRTI SCL SETB ; Issue clocks to help release other devices. SETB R1,#08h MOV ``` **AN444** ``` RC7: 0,0,0,0,0 DB SETB SCL DB 0,0,0,0,0 D.TNZ R1,RC7 CLR SCL DB 0,0 CLR SDA DB SETB SCL DB 0,0,0,0,0 SETB SDA 0,0,0,0,0 ; Issue a Stop. MOV I2CON, #BCXA+BCDR+BCARL+BCSTR+BCSTP; clear flags SETR Main Program ; Message ping pong game. Each message is transmitted by ; a processor that is a master on the I2C bus, and it contains one byte ; of data. A processor that receives this data byte as a slave increments ; the data by one and transmits it back as a master. The data received is ; confirmed to be a one increment of the data formerly sent, unless ; it is a "reset" value, chosen to be 00h. ; The two participating processors have similar code, where the node ; address of the second processor is the destination address of this ; one, and vice versa. ; The first data byte each processor tries to send is 00h. One of the ; processors will acquire the bus first, and the second processor that will ; receive this "resetting" 00h will not attempt tp confirm it against an ; expected value. It will simply increment and transmit it. Subsequent ; receptions will be confirmed against the expected value, until Offh data ; bytes are sent and the game is effectively reset by the 00h resulting from ; the next increment. ; A toggling output (TogLED) tells the outer world that the "ping pong" ; proceeds well. If something unexpected happens we temporarily activate ; another output, ErrLED. ; The different tasks of the code are performed in a combination of main- ; line program and event routines called from the I2C interrupt service ; routine. Initial set-ups: Load CT1,CT0 bits of I2CFG register, according to the clock crystal used. Load RAM location MYADDR with the I2C address of this processor. We load these values out of ROM table locations (R\_CTVAL and R\_MYADDR). One may, instead, load with a MOV <immediate> command. ;;Reset: MOV SP, #07h ;Set stack location. RESET: CLR MOV DPTR, #R_CTVAL MOVC A.@A+DPTR MOV I2CFG, A ; Load CT1,CT0 (I2C timing, crystal ; dependent). CLR MOV DPTR, #R_MYADDR MOVC A,@A+DPTR ; Get this node's address from ROM table MOV MYADDR, A ; into MYADDR RAM location. CLR OnLED ;; ``` #### AN444 ### Using the P82B715 I<sup>2</sup>C extender on long cables ``` ;;Reset2: CLR ErrLED ; Flash LED. LDELAY RESET2: ACALL ErrLED SETB CLR SETTLAG TRQFLAG CLR FAILCNT, #50h MOV TogLED SETB : ; ; Initialize pin-toggling counter MOV TOGCNT, #050h ; Enable slave operation. ; The Idle bit is set here for a restart situation - in normal ; operation this is redundant, as this bit is set upon power_up reset. ; Slave will idle till next Start. I2CON, #BIDLE ; Enable slave operation. SLAVEN SETB ; Enable interrupts. ; This is necessary for both Slave and Master operations. SETB ; Enable timer I interrupts. ; Enable I2C port interrupts. SETB EI2 SETB EA ; Enable global interrupts. ; Set up Master operation. MASCMD, #0h ; "Regular" master transmissions. DPTR, #PongADDR MOV CLR MOVC A, @A+DPTR DESTADRW, A MOV ; The partner address. The LSB is ; low, for a Write transaction. ; Message length - a single byte. MOV MASTCNT, #01h PPSTART: MOV MasBuf, #00h ; "Ping" transmission: PP2: TRQFLAG SETB SETB MASTRO MOV R1,#0ffh PP22: JNB TRQFLAG, PP3 : Transmitted OK R1, PP22 D.TNZ MFAIL1: DJNZ FAILCNT, PP2 ACALL MORERR ::INCREMENT TITOCNT ACALL RECOVER SJMP Reset2 ; "Pong" reception: PP3: MOV RO, #Offh ; Software timeout loop count. MOV R1,#0ffh PP31: TRQFLAG, PP2 PP32: JB ; Rcvd ok as slave, go transmit. JB SETTFLAG, PP5 DJNZ R1, PP32 R0, PP31 DJNZ PPTO: ACALL RECOVER ; Software timeout. AJMP Reset2 ;;PP5: CLR ErrLED ; Receive error. ;; ACALL LDELAY ErrLED ;; SETB PP5: CLR SETTFLAG AJMP PPSTART LDELAY: MOV R2,#030h :LONG DELAY R1,#0ffh LDELAY1: VOM DJNZ R1,$ DJNZ R2, LDELAY1 RET ``` **AN444** ``` Slave and Master Event Routines. Invoked upon completion of a message transaction. This is the part of the application program actually dealing with the data communicated on the I2C bus, by responding to new data received and/or preparing the next transaction. ; Slave Event Routines ; These routines are invoked by the I2C interrupt service routine when a ; message transaction as a slave has been completed. Our "application" ; reacts to a message received as a slave with the routine SRCvdR. ; The calls that indicate erroneous reception are treated the same way as ; erroneous data reception in the "ping pong" game. Invoked when a new message has been received as a Slave. SRcvdR: MOV A, SRcvBuf JNZ SR2 MOV MasBuf, #01h ; It was ping-pong reset value SJMP SR2: INC MasBuf ; The expected data. CJNE A, MasBuf, ErrSR TNC MasBuf ; Data for next transmission - the data ; received incremented by 1. A successful two way data exchange. Let the outside world know by toggling an output pin driving a LED. We actually toggle only when a number of such exchanges is completed, in order to slow down the changes for a good visual indication. DJNZ TOGCNT, SR3 CPL TogLED ; ; ; Toggle output XRL TITOCNT, #80H ;;TOGGLE MSB LED MOV TOGCNT, #050h SETB PSW.3 ;;RS TO 1 MOV LED, @R0 ;; RAM POINTED TO BY RO CLR PSW. 3 ;;RS BACK TO 0 SR3: CLR SErrFLAG SETB TRQFLAG ; Request main to transmit RET ErrsR: SETB SETTFLAG RET Invoked when a message received as a Slave is too long : for the receive buffer. STXedR Invoked when a Slave completed transmission of its buffer. We do not expect to get here, since we do not plan to have in our system a master that will request data from this node. SRErrR Slave error event subroutine. In most applications it will not be used. SLnRcvdR: STXedR: SRErrR: JMP ErrSR ``` June 1993 AN444 ``` MastNext - Master Event Routine. Invoked when a Master transaction is completed, or terminated "willingly" due to lack of acknowledge by a slave. ; MastNext: MOV A, MSGSTAT A, #MTXED, MN1 CJNE MOV FAILCNT, #50h CLR TRQFLAG RET MN1: RET ; I2CDONE Called upon completion of the I2C interrupt service routine. In this example it monitors exceptions, and invokes the bus recovery routine when too many occurred. I2CDONE: MOV A, MSGSTAT CJNE A, #NOTSTR, I2CD1 ;;INCREMENT TITOCNT ACALL MORERR DJNZ FAILCNT, I2CD1 MOV FAILCNT, #01h ; Too many "illegal" i2c interrupts ; - shut off. CLR EI2 I2CD1: RET I2C Communications Table: ; We used table driven values for clarity. One may use immediates to load ; these values and save several lines of code. ; Contents is used in the beginning of the main program to load ; RAM location MYADDR and the I2CFG register. ; The node address, in R_MYADDR, is application specific, and unique for ; each device in the I2C network. ; R_CTVAL depends on the crystal clock frequency. : This node's address R MYADDR: DB ;; NOTE THAT R_MYADDR AND PongADDR ;; MUST BE SWITCHED ON THE OTHER ;;'751 R CTVAL: DB 02h ; CT1, CT0 bit values Application Code Definitions ; The address of the "partner" in PongADDR: DB 4Eh ; the ping-pong game. THIS PROGRAM RUNS THE MONITOR ON THE SMALL TEST BOARD DESIGNED TO TEST THE 12C DRIVER CHIP. : : IT USES A '751. ;; LED EQU 022H LDEL + 1 HDEL EQU ``` **AN444** ``` EQU P1 TOG EQU P0.2 ; TOGGLE SWITCH RNAME EQU R0 ;R0 RAM POINTER ; ; DONMON: MOV #09H SP, ;SP=09,STARTS AT OAH SETB PSW.3 :RS = 01 CLR PSW.1 ;PSW.1 FLAG=0 JB TOG, ONLYAD ; IF TOG 1, PSW1=0 SETB PSW.1 ; WRITE DESIRED ONLYAD: JNB TOG, ONLYAD ; WAIT FOR HI HIWAIT: JB TOG, HIWAIT ; NOW WAIT FOR LOW ; DELAY TIMER MOV #0 LDEL, MOV HDEL, #0 SDELAY: DJNZ LDEL, SDELAY ; DELAY LOOP D.TNZ HDEL, SDELAY ;UPPER DELAY JB TOG, HIWAIT ; FALSE ALARM, GO BACK MOV RNAME, SWITCH ; VALID HI TO LO MOV LED, @RNAME ; DISPLAY CONTENTS OF ; RAM OF RNAME JNB PSW.1, DONE ; PSW1 FLAG, 0=DONE STAYLO: JNB TOG, STAYLO ; NOW WAIT FOR HI HDELAY: DJNZ HDELAY LDEL, ;LDEL=HDEL=0 HDEL, DJNZ HDELAY JNB TOG, STAYLO ; FALSE ALARM MOV @RNAME, SWITCH ; SUCCESSFUL LO TO HI SWITCH TO RAM MOV LED, RNAME ;DISPLAY WHICH RAM ;LOCATION FOR SWITCH DONE: CLR PSW.3 ;RS BANK BACK TO 0 AJMP RESET ;STARTS PING PONG ; MORERR: PUSH ACC MOV Α, #7FH ;; INCREMENT TITOCNT ANL TITOCNT Α, XRL Α, #7FH ;;STOP AT 7F JΖ NOUP INC TITOCNT SETB PSW.3 ;;RS TO 1 MOV LED, @RO ;;DISPLAY NEW TITOCHT CLR PSW.3 ;;RS BACK TO 0 NOUP: POP ACC RET ; END ``` ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 Author: R.C.J. Brink. Eindhoven #### INTRODUCTION #### 1.1. Purpose This document is a user manual for the I<sup>2</sup>C software module IIC51. It is intended for Intel PLM51 users who need to control an I<sup>2</sup>C bus. This document assumes some basic knowledge about I2C and Intel PLM51. #### 1.2. Scope IIC51 is a software module to provide an Intel PLM51 user with a set of procedures to control a bi-directional I<sup>2</sup>C bus. These procedures have been coded in Intel ASM51 and have been optimized for speed. IIC51 supports all common used I2C master transmitter and master receiver protocols. Each different protocol corresponds to one of the procedures in IIC51. IIC51 is available in two different versions: #### IIC51S: IIC51S is a module for singlemaster I<sup>2</sup>C to be used on microcontrollers of the 8XC51 family. It directly controls the microcontroller I/O pins by software without the need of any specific hardware. No other I<sup>2</sup>C masters are allowed on the bus. Note that the electrical characteristics of this microcontroller family are not conform the I<sup>2</sup>C specifications. IIC51M is a module for multimaster I2C to be used on microcontrollers of the PCB8XC552/C652 family. It makes use of the built-in I2C interface hardware (SIO1) of these microcontrollers. Since this hardware is a multimaster interface, other I2C masters are allowed on the All I<sup>2</sup>C transfer procedures in IIC51S are fully software interface compatible with IIC51M. This allows a single PLM51 program using I<sup>2</sup>C to be written for both mentioned microcontroller families. #### 1.3. Definitions, Acronyms and Abbreviations | I <sup>2</sup> C | Inter-IC bus | |-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PLM51<br>ASM51<br>RL51 | High level Program Language for 8051 family Microcontrollers<br>Assembly Language for 8051 family Microcontrollers<br>Relocating Linker for 8051 family Microcontrollers | | S<br>P<br>A<br>N<br>SivW<br>SivR<br>Sub | I <sup>2</sup> C Message Start Condition I <sup>2</sup> C Message Stop Condition I <sup>2</sup> C Message Acknowledge I <sup>2</sup> C Message Negative Acknowledge I <sup>2</sup> C Message Slave Address + Write I <sup>2</sup> C Message Slave Address + Read I <sup>2</sup> C Slave Subaddress | | | 120 0 1 11 11 11 11 11 11 11 11 11 11 11 1 | NV-Memory I<sup>2</sup>C Controlled Non Volatile Memory (E<sup>2</sup>PROM) #### 1 | <ul> <li>1.4. References</li> <li>5. I<sup>2</sup>C Specification I<sup>2</sup>C-bus compatible ICs Philips Components Data Handbook IC12a</li> </ul> | 1989 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | PL/M-51 User's Guide for DOS Systems Intel Corporation | 1986 | | 7. MSC-51 Macro Assembler User's Guide for DOS Systems Intel Corporation | 1986 | | MSC-51 Utilities User's Guide for DOS Systems<br>Intel Corporation | 1986 | | <ol> <li>Single-chip 8-bit microcontrollers PCB83C552/PCB80C552,<br/>l<sup>2</sup>C-bus compatible ICs<br/>Philips Components Data Handbook IC12a</li> </ol> | PCB83C652/PCB80C652 etc. | | 10. Single-chip 8-bit microcontroller PCB80C51 Integrated circuits Book IC14 | 1987 | 206 May 1989 ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### 2. GENERAL DESCRIPTION #### 2.1. Perspective IIC51 is designed for use in stand-alone microcontroller I<sup>2</sup>C systems. It is mainly written to provide a standard set of procedures for computer controlled television/teletext concepts based on 8051 family microcontrollers. #### 2.2. Functions IIC51 contains the following functions: - Initialisation of the I2C interface (software and hardware) - Transfer of I<sup>2</sup>C messages to and from an I<sup>2</sup>C slave device - Error detection - Automatic retrying if an error occurs during a transfer (up to 5 attempts) - Error recovery if the bus is held by a slave device that is out of bit-sync - Optional slave receiver/transmitter function (IIC51M only) #### 2.3. User Characteristics IIC51 is designed to be an easy to use package. All needed code and data is defined in a single object module (IIC51M.OBJ or IIC51S.OBJ). The PLM51 user needs only to link this module to his own application object modules, using Intel's RL51. Procedures and data of concern to the user can be declared EXTERNAL by including the file IIC51.DCL. #### 2.4. General Constraints IIC51 is coded for and translated by the Intel MSC-51 Macro Assembler. It is tested together with Intel PLM51 modules. Intel utilities used for testing: - MSC-51 Macro Assembler, ASM51.EXE, Version V2.3 - PL/M-51 Compiler, PLM51.EXE, Version V1.2 and V1.3 - MSC-51 Relocator and Linker, RL51.EXE, Version V3.1 Development is done on an IBM-PC/AT running DOS. #### IIC51S needs: - 350 Bytes CODE (approx.) - 6 Bytes DATA - 1 Byte Bit-Addressable DATA - 1 Bit #### **IIC5MS** needs: - 400 Bytes CODE (approx.) - 6 Bytes DATA - 1 Byte Bit-Addressable DATA - 1 Bit - Exclusive use of Register Bank 1 ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### 3. FUNCTIONAL DESCRIPTION #### 3.1. Master Mode Functions This section describes the available functions in IIC51 on a procedure by procedure basis. Each procedure must be declared EXTERNAL by the PLM51 user. In this declaration the user can specify the type returned by each procedure. All procedures (except Init\_IIC) can return a BIT or a BYTE (depending on the chosen EXTERNAL declaration). The BIT or BYTE returned is 0 if the I<sup>2</sup>C transmission was successful. If the user decides to declare a procedure untyped, the result of the previous I<sup>2</sup>C transmission can always be checked by examining the static BIT variable IIC\_Error. Note that typed procedures must be called using an expression. If the result of an I<sup>2</sup>C procedure is to be ignored, a dummy assignment must be done for a typed procedure. An untyped procedure can be called by the PLM51 CALL statement, without any additional overhead. The examples in the following section assume the procedures to be declared untyped. Note that the least significant bit of all slaveaddresses passed to the I<sup>2</sup>C procedures must be 0. #### 3.1.1. Init IIC #### **Declaration:** ``` Init_IIC: PROCEDURE ( Own_Slave_Address ) EXTERNAL ; DECLARE ( Own_Slave_Address ) BYTE ; END ; ``` #### Description: Init\_IIC must be called once after reset, before any other procedure is used. It initialises all I<sup>2</sup>C internal static data and hardware. The Own\_Slave\_Address is passed to Init\_IIC for the optional slave function in a multimaster I<sup>2</sup>C system (IIC51M). In a singlemaster I<sup>2</sup>C system (IIC51S), the Own\_Slave\_Address is ignored. Note that Init\_IIC does not effect the global interrupt enable flag (EA). IIC51M requires the user to enable interrupts afterwards (see example). #### Example: ``` CALL Init_IIC ( 54h ) ; ENABLE ; /*Enable Interrupts; EA = 1 */ ``` #### 3.1.2. IIC\_Test\_Device #### Declaration: ``` IIC_Test_Device: PROCEDURE ( Slave_Address ) [ BIT | BYTE ] EXTERNAL ; ``` #### Description: IIC\_Test\_Device just sends the slaveaddress on the I<sup>2</sup>C bus. It can be used to check the presence of a device on the I<sup>2</sup>C bus. #### I<sup>2</sup>C Protocol: #### Example: ``` DECLARE IIC_Error BIT EXTERNAL; ...... CALL IIC_Test_Device ( 8Ch ); IF (IIC_Error ) THEN "Device is Not Present Handling" ELSE "Device is Present Handling" ``` ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### 3.1.3. IIC\_Write #### Declaration: ``` IIC_Write: PROCEDURE ( Slave_Address, Count, Source_Ptr ) [ BIT | BYTE ] EXTERNAL ; DECLARE ( Slave_Address, Count, Source_Ptr ) BYTE ; END ; ``` #### Description: IIC\_Write is the most basic procedure to write a message to a slave device. #### I2C Protocol: ``` L = Count D1[0..L-1] BASED by Source_Ptr ``` | S | SlvW | A | D1[0] | A | D1[1] | A | | A | D1[L-1] | Α | P | | |---|------|---|-------|---|-------|---|----|---|---------|---|---|--| | | | | | | | | // | | | | | | #### Example: ``` DECLARE Data_Buffer ( 4 ) BYTE ; ..... CALL IIC_Write ( OC2h, LENGTH ( Data_Buffer ), .Date_Buffer ) ; ``` #### 3.1.4. IIC\_Write\_Sub #### Declaration: ``` IIC_Write_Sub: PROCEDURE ( Slave_Address, Count, Source_Ptr, Sub_Address ) [ BIT | BYTE ] EXTERNAL ; DECLARE ( Slave_Address, Count, Source_Ptr, Sub_Address ) BYTE ; END ; ``` #### Description: IIC\_Write\_Sub writes a message preceded by a subaddress to a slave device. #### I<sup>2</sup>C Protocol: ``` L = Count Sub = Sub_Address D1[0..L-1] BASED by Source_Ptr ``` | s | SlvW | Α | Sub | Α | D1[0] | A | D1[1] | A | <br>A | D1[L-1] | A | P | |---|------|---|-----|---|-------|---|-------|---|-------|---------|---|---| | | | | | | | | | | | | | | #### Example: ``` DECLARE Data_Buffer ( 8 ) BYTE ; ..... CALL IIC_Write_Sub ( 48h, LENGTH ( Data_Buffer ), .Date_Buffer, 2 ) ; ``` #### 3.1.5. IIC\_Write\_Sub\_SWInc #### Declaration: ``` IIC_Write_Sub_SWInc: PROCEDURE ( Slave_Address, Count, Source_Ptr, Sub_Address) [ BIT | BYTE ] EXTERNAL; DECLARE ( Slave_Address, Count, Source_Ptr, Sub_Address ) BYTE; END; ``` #### Description: Some I<sup>2</sup>C devices addressed with a subaddress do not automatically increment the subaddress after reception of each byte. IIC\_Write\_Sub\_SWInc can be used for such devices the same way IIC\_Write\_Sub is used. IIC\_Write\_Sub\_SWInc splits up the message in smaller messages and increments the subaddress itself. ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### I<sup>2</sup>C Protocol: ``` L = Count Sub = Sub_Address D1[0..L-1] BASED by Source_Ptr s SlvW Sub D1[0] Р S SlvW D1[1] Ρ Α Sub+1 S SlvW Α Sub+L-1 Α D1[L-1] Α P ``` #### Example: ``` DECLARE Data_Buffer ( 6 ) BYTE ; ..... CALL IIC_Write_Sub_SWInc ( 80h, LENGTH ( Data_Buffer ), .Date_Buffer, 0 ) ; ``` #### 3.1.6. IIC\_Write\_Memory #### Declaration: ``` IIC_Write_Memory: PROCEDURE ( Slave_Address, Count, Source_Ptr, Sub_Address) [ BIT | BYTE ] EXTERNAL ; DECLARE ( Slave_Address, Count, Source_Ptr, Sub_Address ) BYTE ; END ; ``` #### Description: I<sup>2</sup>C Non-Volatile Memory devices (such as PCF8582) need an additional delay after writing a byte to it. IIC\_Write\_Memory can be used to write to such devices the same way IIC\_Write\_Sub is used. IIC\_Write\_Memory splits up the message in smaller messages and increments the subaddress itself. After transmission of each small message a delay of 40 milliseconds is inserted. #### I<sup>2</sup>C Protocol: ``` Τ. = Count Sub = Sub_Address D1[0..L-1] BASED by Source_Ptr S SlvW Sub D1[0] P < Delay 40 ms > < Delay 40 ms > S SlvW Sub+1 Α D1[1] Α Ρ S SlvW P < Delay 40 ms > Sub+L-1 Α D1[L-1] Α ``` #### Example: ``` DECLARE Data_Buffer ( 10 ) BYTE ; ..... CALL IIC_Memory ( 0A0h, LENGTH ( Data_Buffer ), .Date_Buffer, 0F0h ) ; ``` ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### 3.1.7. IIC\_Write\_Sub\_Write ``` Declaration: ``` #### Description: IIC\_Write\_Sub\_Write write 2 data blocks preceded by a subaddress in one message to a slave device. This procedure can be used for devices that need an extended addressing method, without the need to put all data into one large buffer. Such a device is the ECCT (I<sup>2</sup>C controlled teletext device; see example). #### I<sup>2</sup>C Protocol: ``` L = Count1 M = Count2 Sub = Sub_Address D1[0..L-1] BASED by Source_Ptr1 D2[0..M-1] BASED by Source_Ptr2 ``` | S | SlvW | A | Sub | А | D1[0] | A | D1[1] | A | // | A | D1[L-1] | А | | |---|------|---|-----|---|-------|---|-------|---|----|---|---------|---|---| | | | | | | | | | T | | | | | | | | | | | | D2[0] | A | D2[1] | A | | A | D2[M-1] | A | P | #### Example: ``` PROCEDURE Write_CCT_Memory ( Chapter, Row, Column, Data_Buf, Data_Count ) ; DECLARE ( Chapter, Row, Column, Data_Buf, Data_Count ) BYTE; /* The extended address (CCT-Cursor) is formed by Chapter, Row and Column. These three bytes are written after the subaddress (8) followed by the actual data which will be stored relative to the extended address. */ CALL IIC_Write_Sub_Write ( 22h, 3, .Chapter, 8, Data_Buf, Data_Count ) ; END Write_CCT_Memory ; ``` #### 3.1.8. IIC\_Read #### Declaration: ``` IIC_Read: PROCEDURE ( Slave_Address, Count, Dest_Ptr ) [ BIT | BYTE ] EXTERNAL ; DECLARE ( Slave_Address, Count, Dest_Ptr ) BYTE ; END ; ``` #### Description: ICC\_Read is the most basic procedure to read a message from a slave device. #### I2C Protocol: ``` M = Count D2[0..M-1] BASED by Dest_Ptr S SlvR A D2[0] A D2[1] A ..... A D2[M-1] N ``` #### Example: ``` DECLARE Data_Buffer ( 4 ) BYTE ; .... CALL IIC_Read ( 0B4h, LENGTH ( Data_Buffer ), .Data_Buffer ) ; ``` P ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### 3.1.9. IIC\_Read\_Status #### **Declaration:** ``` IIC_Read_Status: PROCEDURE ( Slave_Address, Dest_Ptr ) [ BIT | BYTE ] EXTERNAL ; DECLARE ( Slave_Address, Dest_Ptr ) BYTE ; END ; ``` #### Description: A lot of I<sup>2</sup>C devices have only a one status byte that can be read via I<sup>2</sup>C. IIC\_Read\_Status can be used for this purpose. IIC\_Read\_Status works the same as IIC\_Read but the user does not have to pass a count parameter. #### I<sup>2</sup>C Protocol: ``` M = Count Status BASED by Dest_Ptr S SlvR A Status N P ``` #### Example: ``` DECLARE Status_Byte BYTE ; ..... CALL IIC_Read_Status ( 84h, .Status_Byte ) ; ``` #### 3.1.10. IIC\_Read\_Sub #### Declaration: ``` IIC_Read_Sub: PROCEDURE ( Slave_Address, Count, Dest_Ptr, Sub_Address ) [ BIT | BYTE ] EXTERNAL ; DECLARE ( Slave_Address, Count, Dest_Ptr, Sub_Address ) BYTE ; END ; ``` #### Description: IIC\_Read\_Sub reads a message from a slave device preceded by a write of the subaddress. Between writing the subaddress and reading the message, an I<sup>2</sup>C restart condition is generated without surrendering the bus. This prevents other masters from accessing the slave device in between and overwriting the subaddress. #### I<sup>2</sup>C Protocol: ``` M = Count Sub = Sub_Address D2[0..M-1] BASED by Dest_Ptr ``` | Г | | | | | | | | | | | | | // | | | | 1 1 | |---|---|------|---|-----|---|---|------|---|-------|---|-------|---|-------|---|---------|---|-----| | | s | SlvW | A | Sub | Α | S | SlvR | A | D2[0] | A | D2[1] | A | | Α | D2[M-1] | N | P | | L | | | | l | | | | | | | | L | L , , | | | | | #### Example: ``` DECLARE Data_Buffer ( 5 ) BYTE ; ..... CALL IIC_Write_Sub ( 0A2h, LENGTH ( Data_Buffer ), .Data_Buffer, 2 ) ; ``` #### 3.1.11. IIC\_Write\_Sub\_Read #### **Declaration:** #### Description: IIC\_Write\_Sub\_Read writes a data block preceded by a subaddress, generates an I<sup>2</sup>C restart condition, and reads a data block. This procedure can be used for devices that need an extended addressing method. Such a device is the ECCT (I<sup>2</sup>C controlled teletext device; see example). ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### I2C Protocol: ``` L = Count1 M = Count2 Sub = Sub_Address D1[0..L-1] BASED by Source_Ptr1 D2[0..M-1] BASED by Dest_Ptr2 ``` | S | SlvW | А | Sub | А | D1[0] | А | D1[1] | Α | [ ] // <del>-</del> | А | D1[L-1] | A | | |---|---------------------------------------|---|------|---|-------|---|-------|---|---------------------|----------|---------|---|---| | | · · · · · · · · · · · · · · · · · · · | | | | | | | | | <b>1</b> | | | | | | | S | SlvR | A | D2[0] | A | D2[1] | А | | A | D2[M-1] | N | P | #### Example: ``` PROCEDURE Read_CCT_Memory ( Chapter,Row, Column, Data_Buf, Data_Count ); DECLARE ( Chapter, Row, Column, Data_Buf, Data_Count ) BYTE ; /* The extended address (CCT-Cursor) is formed by Chapter, Row and Column. These three bytes are written after the subaddress (8). After that the actual data will be read relative to the extended address. */ CALL IIC_Write_Sub_Read ( 22h, 3, .Chapter, 8, Data_Buf, Data_Count ) ; END Read_CCT_Memory ; ``` #### 3.2. Slave Mode Functions I<sup>2</sup>C slave mode is provided by IIC51M only. All slave mode actions (except initialisation) take place in the SIO1 interrupt procedure. Slave mode I<sup>2</sup>C protocol is very application dependent. If a specific slave mode is required, the user have to modify three procedures in IIC51M at source level. The following sections describe these procedures. The program examples of the procedures implement an I<sup>2</sup>C slave protocol to read and write the microcontroller's on chip RAM via I<sup>2</sup>C. This can be a useful feature during program development and debugging. #### 3.2.1. Init Slave This procedure is called from IIC\_Init. In this procedure the user can initialise all static data concerning slave mode functions (if any). #### Example: ``` Slave_Sub_Address: db 1 .... Init_Slave: mov Slave_Sub_Address,#0 ; Initialise Sub Address ``` #### 3.2.2. Receive\_Slave Receive\_Slave is a procedure called from the SIO1 interrupt procedure each time a byte is received from another I<sup>2</sup>C master. The procedure can make use of the bit "IICntrl.BYTE1EXPECTED", as defined in IIC51M. This bit is set to logic 1, every time the first data byte of an I<sup>2</sup>C message is about to be received. Receive\_Slave can use this bit to detect the start of a new message. Normally all bytes received from the other master will be acknowledged (i.e., SIO1 control bit Assert Acknowledge is set, AA = 1). If AA is cleared by Receive\_Slave subsequent bytes in the message will be ignored and a negative acknowledge will be transmitted after reception of each byte. Note that the example does not make use of this feature. #### Constraints: - Receive\_Slave must read the S1DAT register. - Receive\_Slave may clear the SIO1 control bit AA, to stop acknowledging data. - Receive\_Slave may not effect any other SIO1 hardware registers/bits. - Receive\_Slave is only allowed to use the accumulator and register R0 in the current registerbank. #### Example: ``` Receive_Slave: mov a,S1DAT ; Pick up data ; Prepare for 1st byte jbc IICCntrl.BYTE1EXPECTED,Save_Byte ; Jump if 1st byte mov r0,Slave_Sub_Address inc Slave_Sub_Address ; Postincrement Sub. Save_Byte: mov @r0,a ; Save_Data ; Exit ``` ### PLM51 I<sup>2</sup>C software interface IIC51 (version 0.5) ETV/AN89004 #### 3.2.3. Send Slave Send\_Slave is a procedure called during the SIO1 interrupt procedure each time a byte has to be transmitted to another I<sup>2</sup>C master. This occurs after reception of I<sup>2</sup>C startcondition followed by the microcontroller's own slaveaddress (as passed to Init\_IIC) with read-bit. Send\_Slave will be called again after transmission of each subsequent byte, until a negative acknowledge is received from the reading I<sup>2</sup>C master. #### Constraints: - Send\_Slave must write to the S1DAT register. - Send\_Slave may not effect any other SIO1 hardware registers/bits. - Send\_Slave is only allowed to use the accumulator and register R0 in the current registerbank. #### Example: Send\_Slave: mov r0,Slave\_Sub\_Address mov S1DAT,@r0 ; Pick up Sub Address ; Send Data inc Slave\_Sub\_Address ; Postincrement Sub. ret **EIE/AN91007** Author: J.C.P.M. Pijnenburg, Eindhoven ### 1. INTRODUCTION This report describes the I<sup>2</sup>C drivers which are written for the 8xC751/2. The report describes not only how to use the routines, but also the structure of the software. The software is written around a set of basic routines and a message handler. The message handler does not contain any specific 8xC751 code, so the software can be easily rewritten for any other bit level I<sup>2</sup>C interface by rewriting the set of basic routines. In the rest of this report, when 8xC751 is written, it means 8xC751/2. The package supports also the multimaster features of the I<sup>2</sup>C bus. The maximum bit rate possible when using those routines is approximately 70Kbit/sec. #### References: The I<sup>2</sup>C-bus specification: 80C51-based 8-bit microcontrollers PLM51 I<sup>2</sup>C Software interface I2C51: ETV/AN89004 ### 2. GENERAL ### 2.1 Memory Usage & File Structure The driver software consists of 3 main parts: - I2C message handler - I2C basic routines - I2C slave routines During I<sup>2</sup>C usage it claims register bank 1, however, register bank 1 does not contain any static I<sup>2</sup>C data and can be used by the application program outside the I<sup>2</sup>C routines (this data will be destroyed by I<sup>2</sup>C routines). The accumulator is also modified during I<sup>2</sup>C transfer. The message handler uses a Message Control Block which consists of 8 bytes RAM. In those bytes, the following parameters are stored: For block 1: I2C\_ADDR\_1, BUF\_LEN and BUF\_PTR\_1 For block 2: I2C\_ADDR\_2, BUF\_LEN and BUF\_PTR\_2 2 bytes of bit addressable RAM for STATUS and CONTROL information The STATUS byte is returned into the accumulator. If you do not need a detailed status, you can test the carry bit, this is a copy of the I2C\_ERROR bit of the status register (returned in the acc.). The status register contains the following information: | BIT | NAME | FUNCTION | |-------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | RETRY_0 | In property of the second seco | | 1 | RETRY_1 | I- Retry counter (07), as given during I2C_INIT | | 2 10 10 10 | RETRY_2 | <ul> <li>A. Grand and has been not been a forced with</li> </ul> | | 3 | I2C_ERR | I2C error if set (also available in carry) | | 4 | TIME_ERR | Bus timeout occurred if set | | 5 | RECOVER | - (no value for user) always 0 | | 6, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | BUS_RECOVERED | If set, bus K recovered after timeout | | 7 | NO_ACK | No acknowledge received | The slave function uses 2 bytes of RAM, those contain the own slave address (OWN\_SLV\_ADDR) and a pointer the slave transmit/receive buffer of the 8xC751. This is the buffer from/in which the 8xC751 gets/stores the data bytes in slave mode. The I<sup>2</sup>C module is built around a message handler which calls basic functions such as I<sup>2</sup>C\_TRX\_BYTE and I<sup>2</sup>C\_START. Each function calls the message handler after loading the correct mask into the I<sup>2</sup>C\_CTRL byte. Application note ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 | FILENAME | FUNCTION | INCLUDE/LINK | CODE SIZE (BYTE) | |--------------|-------------------------------------------------------------|------------------------------------------------------|--------------------------------| | I2C_DATA.GLO | I <sup>2</sup> C global data definitions | I, each I <sup>2</sup> C function and assembler main | 0 | | I2C_DATA.LOC | I <sup>2</sup> C local data definitions | I, each I <sup>2</sup> C function | 0.55 | | I2C_CODE.GLO | I <sup>2</sup> C global function definitions | I, assembler main | | | I2C_INIT.ASM | Init_I2C (does not use message handler) | Link | 22 | | I2C_DEF.ASM | Define MCB & _I2C_xxx_BYTEs | Link | 0 | | I2C_HAND.ASM | I <sup>2</sup> C Message handler | Link | 144 | | I2C_BASI.ASM | I <sup>2</sup> C basic functions, and TI interrupt handling | Link | 293 | | I2C_TDEV.ASM | I <sup>2</sup> C Test_Device | Link, if used | 5 | | I2C_WRIT.ASM | I <sup>2</sup> C Write | Link, if used | 5 | | I2C_WSUB.ASM | I <sup>2</sup> C Write_Sub | Link, if used | 5 | | I2C_WSWI.ASM | I <sup>2</sup> C Write_Sub_SWinc & Write_Mem | Link, if used | 36 | | I2C_WSUW.ASM | I <sup>2</sup> C Write_Sub_Write | Link, if used | 5 | | I2C_WSUR.ASM | I <sup>2</sup> C Write_Sub_Read | Link, if used | 5 | | I2C_WCOW.ASM | I <sup>2</sup> C Write_Com_Write | Link, if used | 11 30 30 30 30 30 | | I2C_WREW.ASM | I <sup>2</sup> C Write_Rep_Write | Link, if used | <b>5</b> (a term of a section) | | I2C_WRER.ASM | I <sup>2</sup> C Write_Rep_Read | Link, if used | 5 he juit in part | | I2C_READ.ASM | I <sup>2</sup> C Read and Read_Status | Link, if used | <b>11</b> | | I2C_RSUB.ASM | I <sup>2</sup> C Read_Sub | Link, if used | 5 | | I2C_RRER.ASM | I <sup>2</sup> C Read_Rep_Read | Link, if used | 5 | | I2C_RREW.ASM | I <sup>2</sup> C Read_Rep_Write | Link, if used | 5 | | I2C_SLAV.ASM | I <sup>2</sup> C Slave Function | <b>Link</b> | 56 | | | | | | The total memory usage for the full package is ROM : 520 (single function) to 623 (all functions) bytes RAM byte addressable : 8 bytes bit addressable : 2 bytes register bank 1 : 8 bytes The message handler, causes the other functions to be very small, to further reduce the code, all functions are placed in separate modules, which are put into a library I2C\_751.LIB. If this library is linked to an application program, only the object modules which are used by the application program are linked in the output file. The I2C\_CODE.H file contains the references to the separate functions (EXTRN CODE definitions). The use must not include this file into main, but only copy the definitions which he needs into the source file. If this file is included, all functions will be linked, the library approach is of no use in this case. ### 2.2 Retries During initialization, the user defines whether he wants to use retries or not. If an I<sup>2</sup>C message fails, and retries >=0, the program restarts the message. This is done for at most 7 times. If the message remains unsuccessful, the message handler returns to the main program, indicating that the message has failed (carry set). ### 2.3 Error Handling In case of an error while operating as master, the program returns to the message handler. The message handler decides whether to invoke a retry or to return to the main program. The I<sup>2</sup>C interface of the 8xC751 generates a timeout interrupt if the bus hangs for more than 1022 cycles, in this case, if the 8xC751 is master (RECOVER = 1), a bus recover routine is started, if the 8xC751 is not master, the I<sup>2</sup>C bus is released. Retries are only invoked in the master situation. ### 2.4 Development Tools The following software tools from Tasking/BSO are used for program development: - OM4142 Cross Assembler 8051 for DOS: V3.0b - OM4144 PL/M 8051 Compiler for DOS: V3.0a - OM4136 C8051 Compiler for DOS: V1.1a - OM4129 XRAY51 debugger: V1.4c #### **MASTER ROUTINES** ### 3.1 Message Handler To make the I<sup>2</sup>C protocols as described in paragraphs 3.2 to 3.15, and I<sup>2</sup>C message handler is written. The message control block (I<sup>2</sup>C\_MCB) together with the I<sup>2</sup>C control byte (I2C\_CTRL) form the input for the message handler. The I2C\_MCB includes 6 bytes of data, containing: first address in the protocol - BUF\_LEN\_1, length of the first data buffer - BUF\_PTR 1, pointer to the first data buffer - I2C\_ADDR2, second address in the protocol - BUF\_LEN\_2, length of the second data buffer - BUF\_PTR\_2, pointer to the second data buffer The I2C CTRL byte is bit addressable. It contains 8 bits that determine the flow through the message handler. This byte must be loaded with the corresponding mask before starting the message handler. The I2C\_CTRL byte contains the following bits: - REP\_STRT\_BLK1 must we send a repeated start before the first data block? (0=NO, 1=YES) - RWN\_BLK1 read (1) or write (0) the first block of data is there a second address in the protocol? (0=NO, 1=YES) ADDR2 - ADDR2 SUB is the 2nd address a sub address, only relevant if ADDR2=1. - BLOCK2 is there a second block of data in the protocol? (0=NO, 1=YES) - RWN\_BLK1 read (1) or write (0) the first block of data - REP\_STRT\_BLK1 must we send a repeated start before the second data block? - TEST\_DEVICE is it the test device protocol When an I<sup>2</sup>C protocol is handled successfully by the message handler, it returns control to the main program; if not it can do a retry by resending the message (maximum 5 retries are possible). The message handler return value is stored in the I2C\_STAT byte. The I2C\_ERROR bit indicates whether the transfer has succeeded. NOTE: It is better to copy this byte into Acc before returning the control to the main program, this way a byte can be saved (I2C\_STAT can be placed in register bank 1) and the main program can do a JZ/JNZ test (must be changed). ### 3.2 I2C\_INIT ### Description Init\_I2C must be called after RESET, before any procedure is called. The I2C interface and I2C interrupt will be enabled (STEB ETI,EI2 and EA). Own\_Slave\_Address is passed to Init\_I2C for use as slave. Slave\_Sub\_Address is the pointer to a DATA buffer that is used for data transfer in slave mode. When used as master in a single master system, these parameters are not used. Retry is the number of retries on messages when an error occurs. 0 means no retry (just 1 attempt to send a message), while the maximum amount of retries is 7. #### I<sup>2</sup>C Protocol none (no action at I2C bus) #### Calling Sequence С : I2C\_INIT(Own\_Slv\_Addr,Slv\_Buf\_Addr,Retry); PL/M51 : I2C\_INIT(Own\_Slv\_Addr,Slv\_Buf\_Addr,Retry); Assembler : %I2C\_INIT(Own\_Slv\_Addr,Slv\_Buf\_Addr,Retry); (macro call) ### **Parameters** Own\_Slave\_Adr : 8xC751 own slave address Slave\_Buffer\_Adr : Base address of buffer, to transmit data from, or receive data in, when 8xC751 is in slave mode. Retry : Number of times to do a retry in case of an error. 0 = No Retry, maximum retries is 7. #### NOTE: The Init\_12C function enables the I<sup>2</sup>C watchdog timer interrupt (TI). This watchdog generates an interrupt when during and I<sup>2</sup>C transfer, SCL is held longer than 1022 machine cycles (ca. 760µs @ 16MHz). If this time is too short for your application, you can disable the TI (CLR ETI). In this case, the main program must check if a bus hangup occurs, and take proper action when the bus is hangup. 217 July 1991 **EIE/AN91007** ### 3.3 I2C\_TEST\_DEVICE Description I2C\_Test\_Device just sends the slave address to the I2C bus. It can be used to check the presence of a device on the I2C bus. I<sup>2</sup>C Protocol SIv\_W : Slave\_Adr + Write bit S SIV\_W A P Device is present S SIv\_W N P Device is not present **Calling Sequence** C PL/M51 Assembler : I2C\_TEST\_DEVICE(SIv\_Addr); : I2C\_TEST\_DEVICE(SIv\_Addr); : %I2C\_TEST\_DEVICE(SIv\_Addr); (macro call) **Parameters** Slave\_Adr : Slave address of the device to be tested. ### 3.4 I2C\_WRITE #### Description I2C\_Write is the most basic procedure to write a message to a slave device. I<sup>2</sup>C Protocol SIv\_W : Slave\_Adr + Write bit D0..Dn : Data bytes S | SIv\_W | A | D0 | A | D1 | A | D2 | A | ... | A | Dn | A | P **Calling Sequence** C PL/M51 : I2C\_WRITE(Siv\_Addr,Count,Source\_Ptr); : I2C\_WRITE(Siv\_Addr,Count,Source\_Ptr); Assembler : %I2C\_WRITE(Slv\_Addr,Count,Source\_Ptr); **Parameters** Slave\_Adr : Slave address of the device to write to. Count : Number of bytes to transmit (D0 .. Dn, n = count - 1) Source\_Ptr : Pointer to data buffer, to transmit bytes from. (macro call) EIE/AN91007 ### 3.5 I2C\_WRITE\_SUB ### Description I2C\_Write\_Sub writes a message preceded by a sub-address to a slave device. ### I<sup>2</sup>C Protocol Slv\_W : Slave\_Adr + Write bit Sub : Sub\_Adr D0..Dn : Data bytes S SIV\_W A Sub A D0 A D1 A ... A Dn A P ### **Calling Sequence** C : I2C\_WRITE\_SUB(SIv\_Addr,Count,Source\_Ptr,Sub\_Addr); PL/M51 : I2C\_WRITE\_SUB(Slv\_Addr,Count,Source\_Ptr,Sub\_Addr); Assembler : %I2C\_WRITE\_SUB(SIv\_Addr,Count,Source\_Ptr,Sub\_Addr); (macro call) #### **Parameters** Slave Adr : Slave address of the device to write to. Count : Number of bytes to transmit (D0 .. Dn, n = count - 1) Source\_Ptr : Pointer to data buffer, to transmit bytes from. Sub\_Adr : Sub address. ### 3.6 I2C\_WRITE\_SUB\_SWINC ### Description Some I<sup>2</sup>C devices addressed with a sub-address do not automatically increment the sub-address after reception of each byte. I<sup>2</sup>C\_Write\_Sub\_SWInc can be used for such devices the same way as I<sup>2</sup>C\_Write\_Sub is used. I<sup>2</sup>C\_Write\_Sub\_SWInc splits up the message in smaller messages and increments the sub-address itself. ### I<sup>2</sup>C Protocol Slv\_W : Slave\_Adr + Write bit Sub+x : Sub\_Adr+x D0..Dn : Data bytes S | SIv\_W | A | Sub+0 | A | D0 | P S SIv\_W A Sub+n A Dn P ### **Calling Sequence** C : I2C\_WRITE\_SUB\_SWINC(Slv\_Addr,Count,Source\_Ptr,Sub\_Addr); PL/M51 : I2C\_WRITE\_SUB\_SWINC(SIv\_Addr,Count,Source\_Ptr,Sub\_Addr); Assembler : %I2C\_WRITE\_SUB\_SWINC(SIv\_Addr,Count,Source\_Ptr,Sub\_Addr); (macro call) ### **Parameters** Slave\_Adr : Slave address of the device to write to. Count : Number of bytes to transmit (D0 .. Dn, n = count - 1) Source\_Ptr : Pointer to data buffer, to transmit bytes from. Sub\_Adr : Sub address. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 3.7 I2C\_WRITE\_MEMORY #### Description I<sup>2</sup>C Non-Volatile Memory devices (such as PCF8582) need an additional delay after writing a byte to it. I2C\_Write\_Memory can be used to write to such devices the same way I2C\_Write\_Sub is used. I2C\_Write\_Memory splits up the message in smaller messages and increments the sub-address itself. After transmission of each message, a delay of 40 milliseconds (f<sub>XTAL</sub> = 16MHz) is inserted. D0 I<sup>2</sup>C Protocol Slv\_W Sub+x : Slave\_Adr + Write bit D0..Dn : Sub\_Adr+x : Data bytes S | SIv\_W | A | Sub+0 40 mS S SIv\_W A Sub+1 A D1 P 40 mS 40 mS S SIv\_W A Sub+n A Dn P 40 mS **Calling Sequence** С : I2C\_WRITE\_MEMORY(Slv\_Addr,Count,Source\_Ptr,Sub\_Addr); PL/M51 Assembler : I2C\_WRITE\_MEMORY(Slv\_Addr,Count,Source\_Ptr,Sub\_Addr); : %I2C\_WRITE\_MEMORY(Slv\_Addr,Count,Source\_Ptr,Sub\_Addr); (macro call) **Parameters** Slave\_Adr : S : Slave address of the device to write to. Count Source\_Ptr : Number of bytes to transmit (D0 .. Dn, n = count - 1) : Pointer to data buffer, to transmit bytes from. Sub\_Adr : Sub address. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 3.8 I2C\_WRITE\_SUB\_WRITE #### Description I2C\_Write\_Sub\_Write writes 2 data blocks preceded by a sub-address in one message to a slave device. This procedure can be used for devices that need an extended addressing method, without the need to put all data into one large buffer. Such a device is the ECCT (I<sup>2</sup>C controlled teletext device; see example). I<sup>2</sup>C Protocol Slv W : Slave\_Adr + Write bit Sub : Sub\_Adr D1.0..D1.n : Data bytes in first block D2.0..D2.p : Data bytes in second block #### S SIv\_W D1.1 D1.n D2.0 D1.0 **Calling Sequence** С : I2C\_WRITE\_SUB\_WRITE(Siv\_Addr,Count\_1,Source\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr\_2); PL/M51 : I2C\_WRITE\_SUB\_WRITE(SIv\_Addr,Count\_1,Source\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr\_2); : %I2C\_WRITE\_SUB\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr\_2); Assembler (macro call) **Parameters** Slave\_Adr\_1 : Slave address of the device to write to. Count\_1 : Number of bytes to transmit in first block (D1.0 .. D1.n, n = count\_1 - 1) Source Ptr 1 : Pointer to first block of data to transmit. Sub\_Adr : Sub address. Count\_2 : Number of bytes to transmit in second block (D2.0 .. D2.p, p = count\_2 - 1) Source\_Ptr\_2 : Pointer to second block of data to transmit. ### 3.9 I2C WRITE SUB READ #### Description I2C\_Write\_Sub\_Read writes a data block preceded by a sub-address, generates an I2C restart condition, and reads a data block. This procedure can be used for devices that need an extended addressing method. Such a device is the ECCT. #### I<sup>2</sup>C Protocol Slv\_W : Slave\_Adr + Write bit Slv\_R : Slave\_Adr + Read bit Sub : Sub\_Adr D1.0..D1.n : Data bytes in first block (write) D2.0..D2.p : Data bytes in second block (read) #### SIv W D1.n SIv\_R #### Calling Sequence : I2C\_WRITE\_SUB\_READ(SIv\_Addr,Count\_1,Source\_Ptr,Sub\_Addr,Count,Dest\_Ptr); PL/M51 : I2C\_WRITE\_SUB\_READ(Slv\_Addr,Count\_1,Source\_Ptr,Sub\_Addr,Count,Dest\_Ptr); Assembler : %I2C\_WRITE\_SUB\_READ(SIv\_Addr,Count\_1,Source\_Ptr,Sub\_Addr,Count,Dest\_Ptr); (macro call) **Parameters** Slave\_Adr\_1 : Slave address of the device to write and read to/from. Count\_1 : Number of bytes to transmit (D1.0 .. D1.n, n = count - 1) Source\_Ptr\_1 : Pointer to first block of data to transmit. Sub\_Adr : Sub address. Count\_2 : Number of bytes to transmit in second block (D2.0 .. D2.p, p = count 2 - 1) Dest\_Ptr\_2 : Pointer buffer to receive second block of data in. July 1991 221 EIE/AN91007 ## 3.10 I2C\_WRITE\_COM\_WRITE ### Description I2C\_Write\_Com\_Write writes two data blocks from different data buffers in one message to a slave receiver. This procedure can be used for devices where the message consists of 2 different data blocks. Such devices are, for instance, LCD-drivers, where the first part of the message consists of addressing and control information, and the second part is the data string to be displayed. #### I<sup>2</sup>C Protocol Slv\_W : Slave\_Adr + Write bit D1.0..D1.n : Data bytes in first block (write) D2.0..D2.p : Data bytes in second block (write) | | S | Slv_W | Α | D1.0 | A | D1.1 | Α | D1.2 | Α | | Α | D1.n | Α | D2.0 | Α | | Α | D2.p | Α | Р | | |--|---|-------|---|------|---|------|---|------|---|--|---|------|---|------|---|--|---|------|---|---|--| |--|---|-------|---|------|---|------|---|------|---|--|---|------|---|------|---|--|---|------|---|---|--| #### **Calling Sequence** C : I2C\_WRITE\_COM\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Count\_2,Source\_Ptr\_2); PL/M51 : I2C\_WRITE\_COM\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Count\_2,Source\_Ptr\_2); Assembler : %I2C\_WRITE\_COM\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Count\_2,Source\_Ptr\_2); (macro call) #### **Parameters** Slave\_Adr : Slave address of the device to write to. Count\_1 : Number of bytes to transmit in first block (D1.0 .. D1.n, n = count\_1 - 1) Source\_Ptr\_1 : Pointer to first block of data to transmit. Count\_2 : Number of bytes to transmit in second block (D2.0 .. D2.p, p = count\_2 - 1) Source\_Ptr\_2 : Pointer to second block of data to transmit. ### 3.11 I2C\_WRITE\_REP\_WRITE #### Description Two data strings are sent to separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. #### I<sup>2</sup>C Protocol Slv1W : Slave\_Adr\_1 + Write bit Slv2W : Slave Adr 2 + Write bit D1.0..D1.n : Data bytes in first block (write to first slave) D2.0..D2.p : Data bytes in second block (write to second slave) S | SIv1W | A | D1.0 | A | D1.1 | A | D1.2 | A | ... | A | D1.n | A | P ### **Calling Sequence** C : I2C\_WRITE\_REP\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr\_2); PL/M51 : I2C\_WRITE\_REP\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr\_2); Assembler : %I2C\_WRITE\_REP\_WRITE(Slv\_Addr,Count\_1,Source\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr\_2); (macro call) #### **Parameters** Slave\_Adr\_1 : Slave address of first device to write to. Count\_1 : Number of bytes to transmit in first block (D1.0 .. D1.n, n = count\_1 - 1) Source\_Ptr\_1 : Pointer to first block of data to transmit. Slave\_Adr\_2 : Slave address of second device to write to. Count\_2 : Number of bytes to transmit in second block (D2.0 .. D2.p, $p = count_2 - 1$ ) Source\_Ptr\_2 : Pointer to second block of data to transmit. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 3.12 I2C\_WRITE\_REP\_READ #### Description A data string is sent and received to/from two separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. #### I<sup>2</sup>C Protocol SIv1W : Slave\_Adr \_1 + Write bit SIv2R : Slave\_Adr\_2 + Read bit D1.0..D1.n : Data bytes in first block (write to first slave) D2.0..D2.p : Data bytes in second block (write to second slave) #### S SIv1W D1.n A S SIv2R D2.0 D2.1 D1.2 Α D2.p #### **Calling Sequence** : I2C\_WRITE\_REP\_READ(SIv\_Addr,Count\_1,Source\_Ptr,Sub\_Addr,Count\_2,Dest\_Ptr); PL/M51 : I2C\_WRITE\_REP\_READ(Slv\_Addr,Count\_1,Source\_Ptr,Sub\_Addr,Count\_2,Dest\_Ptr); Assembler : %I2C\_WRITE\_REP\_READ(Slv\_Addr,Count\_1,Source\_Ptr,Sub\_Addr,Count\_2,Dest\_Ptr); (macro call) #### **Parameters** Slave\_Adr 1 : Slave address of first device to write to. Count\_1 : Number of bytes to transmit in first block (D1.0 .. D1.n, $n = count_1 - 1$ ) Source\_Ptr\_1 : Pointer to first block of data to transmit. Slave\_Adr\_2 : Slave address of second device to read from. : Number of bytes to transmit in second block (D2.0 .. D2.p, p = count\_2 - 1) Count 2 Dest Ptr 2 : Pointer buffer to receive second block of data in. ### 3.13 I2C\_READ #### Description I2C\_Read is the most basic procedure to read a message from a slave device. ### I<sup>2</sup>C Protocol Slv\_R : Slave\_Adr + Read bit D0 .. Dn : Data bytes > SIV R D<sub>0</sub> **D2** Dn ### **Calling Sequence** C : I2C\_READ(Slv\_Addr,Count,Dest\_Ptr); PL/M51 :: I2C\_READ(Slv\_Addr,Count,Dest\_Ptr); Assembler : %I2C\_READ(Slv\_Addr,Count,Dest\_Ptr); (macro call) #### **Parameters** Slave Adr : Slave address of the device to be tested. Count : Number of bytes to transmit (D0 .. Dn, n = count - 1) Dest\_Ptr : Pointer to data buffer, to receive bytes in. 223 July 1991 ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 3.14 I2C\_READ\_STATUS #### Description Several I<sup>2</sup>C devices can send a one byte status-word via the bus. I2C\_Read\_Status can be used for this purpose. I2C\_Read\_Status works the same way as I2C\_Read, but the user does not have to pass a count parameter. I<sup>2</sup>C Protocol Slv\_R : Slave\_Adr + Read bit Status : Status bytes S SIv\_R A Status A P **Calling Sequence** C : I2C\_READ\_STATUS(SIv\_Addr,Dest\_Ptr); PL/M51 : I2C\_READ\_STATUS(SIv\_Addr,Dest\_Ptr); Assembler : %I2C\_READ\_STATUS(SIv\_Addr,Dest\_Ptr); (macro call) **Parameters** Slave\_Adr : Slave address of the device to be tested. $\begin{array}{ll} \mbox{Count} & : \mbox{Number of bytes to transmit (D0 .. Dn, n = count - 1)} \\ \mbox{Dest\_Ptr} & : \mbox{Pointer to data buffer, to receive status byte in.} \\ \end{array}$ ### 3.15 I2C\_READ\_SUB ### Description I2C\_Read\_Sub reads a message from a slave device, preceded by a write of the sub-address. Between writing the sub-address and reading the message, an I<sup>2</sup>C restart condition is generated without releasing the bus. This prevents other masters from accessing the slave device in between and overwriting the sub-address. I<sup>2</sup>C Protocol SIv\_W : Slave\_Adr + Write bit SIv\_R : Slave\_Adr + Read bit Sub : Sub\_Adr S | SIv\_W | A | Sub | A | S | SIv\_R | A | D1 | A | ... | A | Dn | N | P **Calling Sequence** C : I2C\_READ\_SUB(SIv\_Addr,Count,Dest\_Ptr,Sub\_Addr); PL/M51 : I2C\_READ\_SUB(SIv\_Addr,Count,Dest\_Ptr,Sub\_Addr); Assembler : %I2C\_READ\_SUB(SIv\_Addr,Count,Dest\_Ptr,Sub\_Addr); (macro call) **Parameters** Slave Adr : Slave address of the device to be tested. Count : Number of bytes to transmit (D0 .. Dn, n = count - 1) Dest\_Ptr : Pointer to data buffer, to receive bytes in. Sub\_Adr : Sub address. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 3.16 I2C\_READ\_REP\_READ #### Description Two data strings are read from separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. ### I<sup>2</sup>C Protocol Slv1R : Slave\_Adr\_1 + Read bit Slv2R : Slave\_Adr\_2 + Read bit D1.0 .. D1.n : Data bytes in first block (read from first slave) D2.0 .. D2.p : Data bytes in second block (read from second slave) S | SIv1R | A | D1.0 | A | D1.1 | A | D1.2 | A | ... | A | D1.n | N | S | SIv2R | A | D2.0 | A | D2.1 | A | ... | A | D2.p | N | P ### **Calling Sequence** C : I2C\_READ\_REP\_READ(SIv\_Addr,Count\_1,Dest\_Ptr\_1,Sub\_Addr,Count\_2,Dest\_Ptr\_2); PL/M51 : I2C\_READ\_REP\_READ(SIv\_Addr,Count\_1,Dest\_Ptr\_1,Sub\_Addr,Count\_2,Dest\_Ptr\_2); Assembler: %I2C\_READ\_REP\_READ(Slv\_Addr,Count\_1,Dest\_Ptr\_1,Sub\_Addr,Count\_2,Dest\_Ptr\_2); (macro call) #### **Parameters** Slave Adr 1 : Slave address of first device to write to. Count\_1 : Number of bytes to transmit in first block (D1.0 .. D1.n, n = count\_1 - 1) Dest\_Ptr\_1 : Pointer buffer to receive first block of data in. Sub Adr 2 : Slave address of second device to read from. Count 2 : Number of bytes to transmit in second block (D2.0 .. D2.p, p = count\_2 - 1) Dest\_Ptr\_2 : Pointer buffer to receive second block of data in. ### 3.17 I2C\_READ\_REP\_WRITE ### Description A data string is received and sent from/to two separate slave devices, separated with a repeat START condition. This has the advantage that the bus does not have to be released with a STOP condition before the transfer from the second slave. ### I<sup>2</sup>C Protocol Slv1R : Slave\_Adr\_1 + Read bit Slv2W : Slave\_Adr\_2 + Write bit D1.0 .. D1.n : Data bytes in first block (read from first slave) D2.0 .. D1.p : Data bytes in second block (read from second slave) S | SIV1R | A | D1.0 | A | D1.1 | A | D1.2 | A | ... | A | D1.n | N | S | SIV2W | A | D2.0 | A | D2.1 | A | ... | A | D2.p | A | P ### **Calling Sequence** C : I2C\_READ\_REP\_WRITE(SIv\_Addr,Count\_1,Dest\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr); PL/M51 : I2C\_READ\_REP\_WRITE(SIv\_Addr,Count\_1,Dest\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr); Assembler : %I2C\_READ\_REP\_WRITE(Slv\_Addr,Count\_1,Dest\_Ptr\_1,Sub\_Addr,Count\_2,Source\_Ptr); (macro call) ### **Parameters** Slave\_Adr\_1 : Slave address of first device to write to. Count\_1 : Number of bytes to transmit in first block (D1.0 .. D1.n, n = count\_1 - 1) Dest\_Ptr\_1 : Pointer buffer to receive first block of data in. Sub\_Adr\_2 : Slave address of second device to read from. Count\_2 : Number of bytes to transmit in second block (D2.0 .. D2.p, p = count\_2 - 1) Dest\_Ptr\_2 : Pointer buffer to transmit second block of data from. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 4. SLAVE ROUTINES The slave-mode protocol is very application dependent. In this note the basic slave-receive and slave-transmit routines are given and should be considered as examples. The user may, for instance, send NO\_ACK after receiving a number of bytes to signal to the master-transmitter that a data buffer is full. A listing of the slave routines is given in Appendix III. The I<sup>2</sup>C slave function has two entries: - The I<sup>2</sup>c interrupt. - This can only occur at an idle slave, because when a transmission is in progress, the I2C interrupt is disabled. ### 2. Through the master routines. During transmission of a slave-address in master-mode, arbitration is lost to another master. The interface must then switch to slave-receiver mode to check if this other master wants to address the 8xC751 I<sup>2</sup>C interface. If the 8xC751 recognizes his own slave address, the slave mode routines are entered at labels I2C\_SLV\_TRX or I2C\_SLV\_RCV. Interfacing the master routines, if the user wants to adapt the slave routines to his own needs, he has to keep in mind that the master routines use the I2C\_SLV\_TRX and I2C\_SLV\_RCV entries. The I<sup>2</sup>C slave routines are entered after the acknowledge has been sent, therefore the ATN flag will be set when entering the slave routines at I2C\_SLV\_TRX or I2C\_SLV\_RVC. The slave routines, as given, make use of a single data buffer. When addressed as slave transmitter, data bytes from the data buffer are transmitted over the I<sup>2</sup>C bus until a not acknowledge or stop is received. When addressed as slave receiver, the data from the I<sup>2</sup>C bus is received into the data buffer until a not acknowledge or a stop is received. The data buffer is initialized during the Init\_I2C function, one of the parameters of this function is the pointer to the data buffer (SLV\_BUF\_PTR DS 1). #### 4.1 Slave Transmitter The slave transmitter function transmits data bytes from the 8xC751 data buffer (ACALL I2C\_TRX\_BYTE) until a not acknowledge or a stop is received. The function is also exit on an I<sup>2</sup>C error. The function is exit with the ATN bit set. ### 4.2 Slave Receiver The slave receiver function receivers data bytes into the 8xC751 data buffer (ACALL I2C\_RCV\_BYTE) until a stop is received. The function is also exit on an I<sup>2</sup>C error. The function is exit with the ATN bit set. If a byte has been received, an acknowledge is sent. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ### 5. EXAMPLES #### 5.1 Introduction Some examples are given on how to use the I<sup>2</sup>C routines in an application program. Examples are given for an assembly, PL/M and C programs. The program displays time form the PCF8583P clock/calendar/RAM on an LCD display driven by the PCF8577. The example can be executed on the OM4151 I<sup>2</sup>C evaluation board. ### 5.2 Using the Routines in Assembly Sources Appendix VII shows the listing of the example program. The most important aspect when using the I<sup>2</sup>C routines is preparing the input parameters before the sub-routine call. The parameters must be transferred to the MCB (Message Control Block). Below are 2 examples of how to transfer the necessary parameters to MCB (\_I2C\_Read and \_I2C\_Write\_Sub\_Read). ``` MOV _I2C_MCB, #Slave_Adr MOV _I2C_MCB+1, #Count_1 MOV _I2C_MCB+2, #Dest_Ptr_1 ACALL _I2C_READ MOV _I2C_MCB, #S1_Adr MOV _I2C_MCB+1, #Cnt_1 MOV _I2C_MCB+2, #S_Ptr_1 MOV _I2C_MCB+3, #Sub_Adr MOV _I2C_MCB+4, #Cnt_2 MOV _I2C_MCB+5, #S_Ptr_2 ACALL _I2C_MKITE_SUB_READ ``` Note that the order of defining the parameters is the same as in PL/M— and C-calls (Calling sequences in paragraphs 3.2 to 3.17). An easier way to call the routines is to make a macro that includes the to transfer of the parameters. The example program makes use of macros. I2C\_Read is then called in the following way: ``` %I2C_READ(Slave_Adr, Count_1, Source_Ptr_1); ``` Note that in the listing the macro call is replaced by the contents of the macro. The macro must be written as follows: ``` %* DEFINE (I2C_READ(Slave_Adr,Count_1,Dest_Ptr_1)) ( MOV _I2C_MCB,#%Slave_Adr MOV _I2C_MCB+1,#%Count_1 MOV _I2C_MCB+2,#%Dest_Ptr_1 ACALL _I2C_READ ) ``` File I2C\_MAC.DEF contains the macro calls for the routines as described in paragraphs 3.2 to 3.17. This file should be included in all assembler modules in which calls to the I<sup>2</sup>C routines are made. The file I2C\_CODE.GLO contains the global function definitions (EXTRN CODE) of the I<sup>2</sup>C functions, copy the ones you need into your application. The file I2C\_DATA.GLO contains the global data definitions of the I<sup>2</sup>C functions. Therefore, this file must also be included in all assembler modules in which calls to the I<sup>2</sup>C routines are made. All I2C routines return a status into the CY-bit. If the CY-bit is set, and error has occurred. ### 5.3 Using the Routines in PL/M-51 Sources Appendix VIII shows the listing of the example program in PL/M-51. All procedures return a BIT value. The file I2C\_PL/M.H contains the procedure declarations, this file can be included in the modules which call I<sup>2</sup>C routines. The routines are used the same way as in the examples of paragraph 5.2. ### 5.4 Using the Routines in C Sources Appendix IX shows the listing of the example program in C. All functions are return a bit value. The file I2C\_C.H contains the function prototypes, this file can be included in the modules which call I2C routines. The routines are used the same way as in the examples of paragraph 5.2. ## I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ## Read.Me ``` PACKAGE: I2C drivers for 8xC751/2 microcontroller DESCRIPTION: To use the package just link the library: I2c_751.lib to your application program NOTES: If you use the package with assembler sources, you must include \USER\INCLUDE\I2C_DATA.GLO and \USER\INCLUDE\I2C_MAC.DEF into your main application(s). \USER\INCLUDE\I2C_CODE.GLO contains external code definitions, select the ones you need and copy them into your main application* If you include this file, the linker assumes that you use all I2C* functions and therefore links the complete package to your application (in this case the library approach is of no use!) If you use the package with PLM sources, you must include \USER\INCLUDE\12C_PLM.H in each file which uses an I2C function If you use the package with C sources, you must include \USER\INCLUDE\12C_PLM.C in each file which uses an I2C function CONTENTS OF DISK The disk contains 3 directories: 1:\USER :This directory contains 2 directories: \INCLUDE : I2C PLM.H :PLM header file I2C_C.H :C header file I2C_MAC.DEF :ASM header file, Macro definitions for ASM function calls :I2C global data (assembler only) I2C_DATA.GLO I2C_DATA.LOC :I2C local data (assembler only, not for user) I2C_CODE.GLO :I2C extern code definitions (assembler only) REG751.H :8xC751 register file \LIB : LIB.BAT :example batch file to create library I2C_751.LIB :8xC751/2 I2C drive library 2:\EXAMPLE :This directory contains 3 directories \DEMO_ASM :Assembly example :PL/M example \DEMO_PLM \DEMO_C :C example ``` 3:\SOURCE :This directory contains the source files of the modules that are \*----- July 1991 228 put in library with I2C\_751.LIB EIE/AN91007 ## I<sup>2</sup>C Master routines ``` $ TITLE(I2C_DEF.ASM) ______ INCLUDE FILE: 12C_DEF.ASM PACKAGE : I2C This file must be LINKED to each I2C sub function USING(1) GLOBAL DATA DECLARATIONS PUBLIC I2C_MCB 12C_CTRL PUBLIC PUBLIC I2C_STAT PUBLIC OWN_SLV_ADDR PUBLIC SLV_BUF_PTR PUBLIC I2C_ADDR_1 PUBLIC BUF_LEN_1 BUF_PTR_1 PITRI-TC I2C_ADDR_2 PUBLIC PUBLIC BUF LEN 2 PUBLIC BUF PTR 2 GLOBAL FUNCTION DECLARATION * _I2C_INIT_BYTE PUBLIC PUBLIC _I2C_TEST_DEVICE_BYTE _I2C_WRITE_BYTE PUBLIC _I2C_WRITE_SUB_BYTE PUBLIC _I2C_WRITE_SUB_SWINC_BYTE _I2C_WRITE_MEMORY_BYTE PUBLIC _I2C_WRITE_SUB_WRITE_BYTE PUBLIC _I2C_WRITE_SUB_READ_BYTE PUBLIC _I2C_WRITE_COM_WRITE_BYTE PUBLIC _I2C_WRITE_REP_WRITE_BYTE PUBLIC _I2C_WRITE_REP_READ_BYTE PUBLIC _I2C_READ_BYTE PUBLIC _I2C_READ_STATUS_BYTE PUBLIC _I2C_READ_SUB_BYTE PUBLIC _I2C_READ_REP_READ_BYTE PUBLIC _I2C_READ_REP_WRITE_BYTE PUBLIC GLOBAL FUNCTION DEFINITIONS * I2C_MCB_DATA SEGMENT DATA I2C_MCB_DATA _I2C_INIT_BYTE: OWN_SLV_ADDR: DS SLV_BUF_PTR: _I2C_TEST_DEVICE_BYTE: _I2C_WRITE_BYTE: _I2C_WRITE_SUB_BYTE: _I2C_WRITE_SUB_SWINC_BYTE: _I2C_WRITE_MEMORY_BYTE: _I2C_WRITE_SUB_WRITE_BYTE: _I2C_WRITE_SUB_READ_BYTE: _I2C_WRITE_COM_WRITE_BYTE: _I2C_WRITE_REP_WRITE_BYTE: _I2C_WRITE_REP_READ_BYTE: _I2C_READ_BYTE: _I2C_READ_STATUS_BYTE: _I2C_READ_SUB_BYTE: _I2C_READ_REP_READ_BYTE: _I2C_READ_REP_WRITE_BYTE: ``` EIE/AN91007 | I2C_MCB: | DS | 6 | | |------------|-----|------|-----------| | I2C_ADDR_1 | L . | DATA | I2C_MCB+0 | | BUF_LEN_1 | | DATA | I2C_MCB+1 | | BUF_PTR_1 | | DATA | I2C_MCB+2 | | I2C_ADDR_2 | 2 | DATA | I2C_MCB+3 | | BUF_LEN_2 | | DATA | I2C_MCB+4 | | BUF PTR 2 | | DATA | I2C MCB+5 | I2C\_STAT\_DATA SEGMENT DATA BITADDRESSABLE RSEG I2C\_STAT\_DATA I2C\_CTRL: DS 1 I2C\_STAT: DS 1 END ## EIE/AN91007 ``` S TITLE (I2CDATAG.H) INCLUDE FILE: 12CDATA.GLO PACKAGE : I2C This file must be included into each I2C function, and into the MAIN ASSEMBLER program (if exists) It contains the I2C Global data definitions * I2C FREQUENCY SETTINGS This part contains frequency dependent settings of the 8xC751/8xC752 IÿC interface The user can adapt this part to his own wishes. If this part has been changed, the whole IÿC package must be assembled, linked and put into a library The default setting are made for a 16MHz clock frequency, and a 40 mS delay for programming EEPROM * CT1_CT0 002H ;Frequency <= 16.8 MHz Frequency <= 14.25 MHz Frequency <= 11.7 MHz ; 001H 000H ; 003H Frequency <= 9.14 MHz EEPROM_PROG_DELAY EQU 103 ;40 Msec at 16MHz 1 DELAY = 514 * EEPROM_PROG_DELAY * 12/fosc ;*----- END 12C FREQUENCY SETTINGS GLOBAL DATA DEFINITIONS EXTRN DATA (_I2C_INIT_BYTE) EXTRN DATA (OWN_SLV_ADDR) EXTRN DATA (SLV_BUF_PTR) EXTRN DATA (I2C_MCB) EXTRN DATA (I2C_ADDR_1) EXTRN DATA (BUF_LEN_1) EXTRN DATA (BUF_PTR_1) EXTRN DATA (I2C_ADDR_2) EXTRN DATA (BUF LEN 2) EXTRN DATA (BUF_PTR_2) EXTRN DATA (I2C_CTRL) I2C_CTRL.0 REP_STRT_BLK1 BIT REP_BLK1 BIT I2C_CTRL.1 ADDR2 BIT I2C_CTRL.2 ADDR2_SUB BIT I2C_CTRL.3 BLOCK2 BIT I2C_CTRL.4 RWN_BLK2 BIT I2C_CTRL.5 REP_STRT_BLK2 BIT I2C_CTRL.6 TEST_DEVICE I2C_CTRL.7 BIT EXTRN DATA (I2C_STAT) BIT RETRY 0 I2C STAT.0 RETRY_1 BIT I2C STAT.1 BIT RETRY 2 I2C_STAT.2 I2C ERR BIT I2C STAT.3 TIME_ERR BIT I2C_STAT.4 RECOVER BIT I2C_STAT.5 BUS_RECOVERED BIT I2C_STAT.6 NO_ACK BIT I2C_STAT.7 ``` EIE/AN91007 | **============== | =========== | | * | |------------------------------------------------------|----------------------------------------|------------------------------------------------------|------| | * GLOBAL | SYMBOL I | DECLARATIO | NS * | | I2C_START_CTRL I2C_ENABLE I2C_RELEASE | EQU<br>EQU<br>EQU | 0D0H+CT1_CT0<br>080H+CT1_CT0<br>0F4H | | | C_XMTA C_IDLE C_DRDY C_ARL C_STRT C_STP S_RSTR S_STP | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU | 080H<br>040H<br>020H<br>010H<br>008H<br>004H<br>022H | | ### EIE/AN91007 ``` $ TITLE(I2C_DATA.LOC) INCLUDE FILE: I2C_DATA.LOC * PACKAGE : I2C ; * This file must be included into each I2C function, It contains the I2C Local symbol definitions LOCAL SYMBOL DEFINITIONS SDA BIT 81H SCL 80H BIT BUF_PTR SET R0 BUF_LEN SET R1 BIT_CNT SET R2 MESS_RETRY_CNT SET R3 BUS_ERR_CLKS SET R4 MEM_MESS_LEN SET R5 MEM_DELAY_H SET R6 MEM_DELAY_L SET R7 ``` ``` S TITLE (I2C CODE.H) ;*----- INCLUDE FILE: I2C_CODE.H PACKAGE : I2C ; * This file must be included into the ASSEMBLER MAIN It contains the EXTERNAL CODE references (Global function definitions) of the I2C functions GLOBAL FUNCTION DEFINITIONS * EXTRN CODE(_I2C_INIT) EXTRN CODE (_I2C_TEST_DEVICE) EXTRN CODE (_I2C_WRITE) EXTRN CODE (_I2C_WRITE_SUB) EXTRN CODE(_I2C_WRITE_SUB_SWINC) EXTRN CODE (_I2C_WRITE_MEMORY) EXTRN CODE(_I2C_WRITE_SUB_WRITE) EXTRN CODE (_I2C_WRITE_SUB_READ) EXTRN CODE(_I2C_WRITE_COM_WRITE) EXTRN CODE(_I2C_WRITE_REP_WRITE) EXTRN CODE(_I2C_WRITE_REP_READ) EXTRN CODE(_I2C_READ) EXTRN CODE(_I2C_READ_STATUS) EXTRN CODE (_I2C_READ_SUB) EXTRN CODE (_I2C_READ_REP_READ) EXTRN CODE (_I2C_READ_REP_WRITE) ``` EIE/AN91007 ``` $ TITLE(I2C_Init command) SOURCE FILE : 12C_INIT.ASM : I2C PACKAGE $DEBUG INCLUDES * LOCAL SYMBOL DECLARATIONS RETRIES SET R3 SNOLIST $INCLUDE(REG751.H) SINCLUDE (I2C_DATA.GLO) $INCLUDE(I2C_DATA.LOC) SLIST ;* GLOBAL FUNCTION DEFINITIONS * PUBLIC _I2C_INIT CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_INIT.ASM:I2C_INIT============== ; * FUNCTION NAME: I2C_INIT ; * PACKAGE: ; * DESCRIPTION: ;* Initialize I2C interface: set SDA & SCL, enable time out ;* timer, allow 16 MHz (CT1,CT0 = 0). Set the number of ;* retries (max 7) into the I2C_STAT. Bit 7,6 and 5 of the ;* I2C_STAT contain the number of retries. Those bits may ;* not be changed during the IÿC routines. ; * INPUT: Before calling I2C_INIT the main program must take care that the correct parameters are available in OWN_SLV_ADDR, SLV_BUF_PTR and _I2C_INIT_BYTE+2, this is done automatically when using C, PL/M or the pre- defined assembler macro (available in I2C_MAC.DEF) initialized IÿC and retry number in I2C STAT 7..5 I2C INIT: I2CFG, #I2C_ENABLE MOV ;CLR TIRUN, CLR MASTRO SETB ETI SETR EI2 SETB ;enable interrupts ANL OWN_SLV_ADDR,#0FEH ;save slv addr bit 0=0 MOV I2C_STAT, _I2C_INIT_BYTE+2 ANL I2C_STAT,#07H ;I2C_STAT = retries MOV I2CON, #I2C_RELEASE HISTORY ; *----- ;* 03-07-91 J.C. Pijnenburg original version ; *----- ``` ## **EIE/AN91007** ``` $TITLE(I2C age Handler) ;*============== ; * SOURCE FILE : I2C_HAND.ASM ; * PACKAGE : I2C ; * SDEBUG * INCLUDES $NOLIST $INCLUDE(REG751.H) $INCLUDE(I2C_DATA.GLO) $INCLUDE(I2C_DATA.LOC) SLIST * GLOBAL REFERENCES EXTRN CODE (I2C_STOP) EXTRN CODE (I2C_TRX_BYTE) EXTRN CODE(I2C_TRX_ADDR) EXTRN CODE(I2C_RCV_BYTE) EXTRN CODE(I2C_TRX_BLOCK) EXTRN CODE(12C_RCV_BLOCK) EXTRN CODE(I2C_STRT_SLVAD) EXTRN CODE(I2C_RSTRT_SLVAD) ;* GLOBAL FUNCTION DEFINITIONS * PUBLIC I2C_MESS_HAND * LOCAL SYMBOL DECLARATIONS BIT 0E0H ;bit ACC.0 RWN I2C_PSW EQU * CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_HAND.ASM:I2C_MESS_HAND===========* ; * FUNCTION NAME: I2C HAND ; * PACKAGE: I2C ; * DESCRIPTION: Transmit an I2C age, includes error handling ; * ;* INPUT: age control byte I2C_CTRL (bit addressable) ; * age control block I2C_MCB, containing: I2C_ADDR1 (i.e. slave address BUF_LEN1 (i.e. number of bytes to trx.) BUF_PTR1 (i.e. transmit buffer) I2C ADDR2 (i.e. sub address) (i.e. length of second data blk) BUF LEN2 BUF_PTR2 (i.e. second transmit buffer) ;* OUTPUT: I2C_ERROR byte (bit addressable) I2C_MESS_HAND: PUSH PSW VOM PSW, #I2C_PSW ;sel RB1 ;clr all but retry bits ANL I2C_STAT,#07H VOM MESS_RETRY_CNT, I2C_STAT INC MESS_RETRY_CNT ;load retry counter ``` ## EIE/AN91007 ``` RETRY: ANL I2C_STAT, #07H ;clr all but retry bits MOV A, I2C_ADDR_1 ;load SLV_ADDR CLR RWN ; if (subaddress) JB ADDR2_SUB, STRT RWN = 0 C, RWN_BLK1 MOV ;else MOV RWN, C RWN = RWN_BLK1 STRT: ACALL I2C_STRT_SLVAD ; send START+SLV_ADDR+RWN JNB I2C_ERR, CONTINUE ; branch offset to large AJMP EXIT CONTINUE: JB TEST_DEVICE, M_STOP MOV BUF_PTR,BUF_PTR_1 ;load pointer block1 MOV BUF_LEN, BUF_LEN_1 ;load length blodk1 JNB ADDR2_SUB, BLOCK ;if (addr2_sub) MOV A, I2C_ADDR_2 ; load sub address ACALL I2C TRX BYTE trx_byte(sub address0 JB I2C ERR.EXIT if (error) exit (); JNB REP_STRT_BLK1,BLOCK ; if (rep. start blk1) MOV A, I2C_ADDR_1 load slave address SETR RWN read ACALL I2C_RSTRT_SLVAD send RSTART+SLV_ADDR I2C_ERR, EXIT if (error) exit(): BLOCK: JNB RWN BLK1, TRX 1 ;if ((rwn_blk1) == read)) I2C_RCV_BLOCK ACALL ; rcv_block(&data1,cnt1) SJMP END_BLOCK1 TRX_1: ACALL I2C_TRX_BLOCK ; trx_block(&dtat1,cnt1) ENC_BLOCK1: JB I2C_ERR, EXIT ;if (error) exit(); JNB BLOCK2, M_STOP ;if (2nd block of data) MOV BUF_PTR, BUF_PTR_2 MOV BUF_LEN, BUF_LEN_2 JNB ADDR2, DATA2 if (addr2) JNB REP_STRT_BLK2, DATA2 ; if (rep. start blk2) MOV A, I2C_ADDR_2 { set address2 ADDR2_SUB, SET_RWN JNB if(addr2_sub) MOV A, I2C_ADDR_1 set address1 SET RWN: /* same slave */ MOV C,RWN_BLK2 MOV RWN, C modify RWN BLK1 ACALL I2C_RSTRT_SLVAD snd RSTART+SLV_ADDR I2C_ERR, EXIT JB if (error) exit(); DATA2: JUB RWN_BLK2, TRX_2 if ((rwn_blk2)==read) I2C_RCV_BLOCK ACALL rcv_block(&_dat1,c1) SJMP BLOCK_ERR TRX_2: else ACALL I2C TRX BLOCK trx_block(&data1,c1) BLOCK_ERR: JB I2C ERR. EXIT if (error exit(); M_STOP: ACALL I2C STOP JВ I2C_ERR, EXIT if (error exit(); AJMP RESTORE_CONTEXT ; *MPF:::I2C::I2C_HAND.ASM:EXIT================= ;* FUNCTION NAME: ; * PACKAGE: Exit an I2C message. This routine is only entered if an* IÿC error has occured. If more retries must be made, the message is started again. If no retry must be made, * the message handler is left after setting the carry. Carry is 1 indicates that an error has occurred (return* value for C and PL/M calls). If the routine is entered * at the RESTORE_CONTEXT label, no error has occurred ;* OUTPUT: I2C_ERROR byte (bit addressable EXIT: JNB TIME_ERR, TO_RETRY BUS_RECOVERED, RESTORE_CONTEXT ``` EIE/AN91007 ``` TO_RETRY: MOV 12CON, #12C RELEASE MESS_RETRY_CNT, RETRY ; if (no more retries) DJNZ RESTORE_CONTEXT: 12CFG, #12C_ENABLE ; SLVEN=1, MSTRQ=0, TIRN=0 MOV A, I2C_STAT POP PSW ; restore PSW MOV C, I2C_ERR END_MESSAGE: ;label for debugging SETB enable I2C interrupt RET ; with XRAY ;* 12-06-91 J.C. Pijnenburg original version END ``` EIE/AN91007 ``` $TITLE(I2C_Basic Functions) ; * SOURCE FILE : 12C_BASI.ASM PACKAGE : I2C SDEBUG * INCLUDES $NOLIST $INCLUDE(REG751.H) $INCLUDE(I2C_DATA.GLO) $INCLUDE(I2C_DATA.LOC) $LIST * GLOBAL REFERENCES ; *------ EXTRN CODE(I2C_SLV_TRX) EXTRN CODE (I2C_SLV_RCV) EXTRN CODE (ADDR_RECOG) ;* GLOBAL FUNCTION DEFINITIONS* PUBLIC I2C STRT SLVAD PUBLIC I2C_RSTRT_SLVAD PUBLIC I2C_STOP PUBLIC I2C_TRX_BYTE PUBLIC I2C_TRX_ADDR PUBLIC I2C_RCV_BYTE PUBLIC I2C_RCV_ADDR PUBLIC I2C_TRX_BLOCK PUBLIC I2C_RCV_BLOCK PUBLIC ADDR_COMPARE ; *------ INTERRUPT CODE SEGM: TIMER1 * CSEG AT 01BH ; *MPF::::I2C::I2C_INIT.ASM:I2C_TIME_OUT=========== ; * FUNCTION NAME: I2C_TIME_OUT ; * PACKAGE: ; * DESCRIPTION: ;* I2C time out routine, clear timer interrupt, set the ;* TIME_ERR bit. If the 8xC751 was IÿC bus master while the* ;* interrupt occurred (RECOVER = 1), and attempt to recover* ;* the bus is made. To recover, SDA and SCL are set, if SCL remains low, the* IÿC bus cannot be recovered and the routine is left. If SCL is HIGH but SDA is low, 9 additional clocks are genrated. If SDA becomes HIGH, a STOP is made If the 8xC751 was not IÿC bus master (RECOVER = 0), the ;* bus is released. SETB CLRTI SETB TIME_ERR CLR TIRUN AJMP TI_INT CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ``` ## **EIE/AN91007** ``` ; * SOURCE FILE: I2C_BASI.ASM : * PACKAGE: I2C ; * DESCRIPTION: ;* Generate a start condition on the IÿC bus, Set the ;* MASTRQ bit. If 8xC751 has not become master on ATN, ;* switch to receive mode and check if the own slave address is received. ;* INPUT: none ;* OUTPUT: I2C_ERROR (0, no error; 1, error) ; * OUTPUT CONDITION: SCL is stretched I2C_STRT_SLVAD; SETB TIRUN STR, IS_MASTER ;already started ; disable I2C interrupt CLR I2CFG, #I2C_START_CTRL ACALL WAIT_ATN IS_MASTER: JB MASTER, I2C_TRX_ADDR MOV I2CCON, #C_STRT ACALL I2C RCV ADDR I2C_ERR, END_I2C_START JB ACALL ADDR_COMPARE START_ERR: SETB I2C ERR END_I2C_START: RET ; *MPF:::I2C::I2C_BASI.ASM:I2C_REP_STRT=========== ;* FUNCTION NAME: I2C_REP_START ; * PACKAGE: I2C ,* DESCRIPTION: ;* Generate a repeated start condition on the I\ddot{y}C bus ;* The repeated start is generated by setting the XSTR ;* bit. If STR is not set (by hardware), the IÿC bus is ;* released, no check for own slave address is done after a* ;* repeated start. ;* INPUT: none ;* OUTPUT: I2C_ERROR (0, no error; 1, error) ;* OUTPUT CONDITION: SCL is stretched I2C_RSTRT_SLVAD: VOM I2CON, #S_RSTR ACALL WAIT ATN :wait for rising SCL JNB DRDY, I2C_BASIC_ERR MOV I2CON, #C DRDY ACALL WAIT_ATN :wait for rep start INP STR, I2C_BASIC_ERR SJMP I2C_TRX_ADDR ; *MPF:::I2C::I2C_BASI.ASM:I2C_STOP======== ; * FUNCTION NAME: I2C_STOP : * PACKAGE ; * DESCRIPTION: ;* Generate a stop condition on the I2C bus ;* The STOP condition is generated by setting the XSTP bit. ;* If no error occurs, this function is left with IV bus ;* released and TI stopped. In case of an error the bus is ;* released in the message handler. ; * INPUT: none ;* OUTPUT: I2C_ERROR (0, no error; 1, error) I2C_STOP: CLR MASTRO MOM I2CCON, #S_STP ACALL WAIT_ATN ;wait for rising SCL TND DRDY, I2C_BASIC_ERR MOM I2CON, #C_DRDY ACALL WAIT_ATN ;wait for stop ``` I2CON, #I2C\_RELEASE MOV EIE/AN91007 ``` CLR TTRIM RET ; *MPF:::I2C::I2C_BASI.ASM:I2C_TRX_ADDR============== ;* FUNCTION NAME: I2C_TRX_ADDR ; * PACKAGE: ; * DESCRIPTION: This function calls I2C_TRX_BYTE to transmit the slave address, if an arbitration is lost before the last* ;* bit is transmitted, the function receives the remaining * ;* bits (receive mode), and checks whether the own slave ;* address has been received (call ADDR_CMP). ;* INPUT byte to transmit in ACC ;* OUTPUT: I2C_ERROR (0, no error; 1, error);* OUTPUT CONDITION: SCL is stretched I2C_TRX_ADDR: ACALL I2C_TRX_BYTE TNR I2C_ERR, END_TRX_ADDR DJNZ BIT_CNT, CONTINUE AJMP END_TRX_ADDR CONTINUE: JNB ARL, END_TRX_ADDR JB STR, END_TRX_ADDR ;parasitaire START STR, END_TRX_ADDR ;parasitaire STOP CLR I2C_ERR ;clr err for slv func INC BIT_CNT ;correct BIT_CNT CLR 0E0H ;RDAT = 0 to ACC.0 RCV_NEXT_BIT: MOV I2CON, #C_XMTA+C_DRDY+C_ARL ;rcv mode ACALL WAIT_ATN DRDY, RESTORE_ERR JNB MOV C, RDAT RLC DJNZ BIT CNT, RCV NEXT BIT ACALL ADDR_COMPARE RESTORE ERR. I2C_ERR SETB :set err for ret main END TRY ADDR. RET ; *MPF:::I2C::I2C_BASI.ASM:I2C_ADDR_COMPARE=========* ; * FUNCTION NAME: I2C_ADDR_COMPARE ; * PACKAGE: ; * DESCRIPTION: ;* Compares the contents of the accumulator (received address) with the OWN_SLV_ADDR. If equal and the RWN ;* bit is 0 (master transmit, slave receive) I2C_CLV_RCV is ;* called. If equal and the RWN bit is 1 (master receive, ;* slave transmit) I2C_SLV_TRX is called. If not eugal exit ;* I2C_ADDR_COMPARE ;* INPUT: received address in ACC ;* OUTPUT: I2C_ERROR (0, no error; 1, error) ; * OUTPUT CONDITION: SCL is stretched ADDR_COMPARE: A,OWN_SLV_ADDR XRL TZ. SEND_ACK CJNE A, #1, END_ADDR_COMPARE SEND_ACK: MOV I2DAT,#0 ACALL WAIT_ATN DRDY, END_ADDR_COMPARE JZ SLAVE_RCV AJMP I2C_SLV_TRX SLAVE_RCV: AJMP I2C_SLV_RCV END_ADDR_COMPARE: ``` ## EIE/AN91007 ``` ; *MPF:::I2C::I2C_BASI.ASM:I2C_BASIC_ERR=========== ;* FUNCTION NAME: I2C_BASIC_ERR * PACKAGE: I2C ; * DESCRIPTION: ;* Set the I2C_ERR bit. The message handler tests this bit ;* INPUT: none ;* OUTPUT: I2C_ERROR = 1 I2C_BASIC_ERR: SETB I2C_ERR RET ; *MPF:::I2C::I2C_BASI.ASM:I2C_TRX_BYTE============= * FUNCTION NAME: I2C_TRX_BYTE * PACKAGE: 12C * DESCRIPTION: ;* Transmit a byte over the I2C bus. NOTE: The STR bit is cleared here instead of in the I2C_START routine, because there must be valid data in I2DAT before STR may be cleared (also releases the SCL line). The I2C_TRX_BYTE function transmits a byte over the IÿC bus, after the last bit has been transmitted, ;* the function switches to receive mode to receive the acknowledge bit. If NACK is received, the NO_ACK bit is set. If arbitration is lost or an error occurs during ;* I2C_TRX_BYTE the function is exit with the I2C_ERR bit set. ;* INPUT: byte to transmit in ACC ;* OUTPUT: I2C ERROR (0, no error; 1, error) ;* OUTPUT CONDITION: SCL is stretched I2C_TRX_BYTE: MOV BIT_CNT, #8 TRX_BIT: MOV I2DAT, A ;release SCL I2CON, #C_STRT ; if STR clear STR ;else dummy MOV ACALL WAIT_ATN JNB DRDY, I2C_BASIC_ERR RL DJNZ BIT CNT.TRX BIT MOV I2CON, #C_XMTA+C_DRDY ;receive mode ACALL WAIT_ATN .TNR DRDY.I2C BASIC ERR JNB RDAT, TRX_BYTE_RDY ; stretch SCL SETB NO_ACK TRX_BYTE_RDY: RET ; *MPF:::I2C::I2C_BASI.ASM:I2C_RCV_BYTE===========* ; * FUNCTION NAME: I2C_RCV_BYTE ; * PACKAGE: ; * DESCRIPTION: Receive a byte from te I2C bus ;* This is one function which receives a byte into acc. RCV_BYTE first releases the SCL and then receives the 8 * ;* bits. If RCV_ADDR is called, the first bit is already in* the RDAT register, this must first be saved before the ;* SCL is released. ;* INPUT: none ;* OUTPUT: I2C_ERROR (0, no error; 1, error) if (! I2C_ERROR) received byte in ACC. I2C_RCV_BYTE: MOV I2CON, #C_XMTA+C_DRDY ; rel. SCL, rcv mode I2C RCV_ADDR: MOV BIT_CNT,#8 ; rcv first bit ``` EIE/AN91007 ``` RCV_BIT: ACALL WAIT_ATN JNB DRDY, I2C_BASIC_ERR DJNZ BIT_CNT, NOT_LAST_BIT MOV C, RDAT RLC RET NOT LAST BIT: A. I2DAT ; save bit, rel. SCL ORL RT. SITMP RCV_BIT ; *MPF:::I2C::I2C_BASI.ASM:I2C_TRX_BLOCK============= ;* FUNCTION NAME: I2C_TRX_BLOCK ; * PACKAGE: I2C ;* DESCRIPTION: ;* Transmit a block of bytes over the I2C bus ;* The I2C_TRX_BLOCK function transmits as much bytes as ;* defined in BUF_LEN (set R2), before the message handler * ;* is called, BUF_LEN_1 or BUF_LEN_2 is copied into BUF_LEN* ;* INPUT: pointer to begin of block data in BUF_PTR (R0) byte counter in BIF_LEN (R2) ;* OUTPUT: I2C_ERROR (0, no error; 1, error) I2C_TRX_BLOCK: MOV A, @BUF_PTR ;load byte ACALL I2C_TRX_BYTE JB I2C_ERR, END_TRX_BLOCK JB NO_ACK, END_TRX_BLOCK INC BUF_PTR DJNZ BUF_LEN, I2C_TRX_BLOCK END_TRX_BLOCK: RET ; *MPF:::I2C::I2C_BASI.ASM:I2C_RCV_BLOCK============* ;* FUNCTION NAME: I2C_RCV_BLOCK ; * PACKAGE: I2C ; * DESCRIPTION: ;* Receive a block of bytes from the I2C bus ;* The I2C_RCV_BLOCK function receives as much bytes as defined in BUF_LEN (set R2), before the message handler * ;* is called, BUF_LEN_1 or BUF_LEN_2 is copied into BUF_LEN* ;* INPUT: pointer to begin of receive buffer BUF_PTR (R0) byte counter in BUF_LEN (R2) ;* OUTPUT: I2C_ERROR (0, no error; 1, error) if (!I2C_ERROR) received bytes in buffer. ACK_RCV_BYTE: MOV I2DAT,#0 :send ACK ACALL WAIT_ATN JNB DRDY, I2C_BASIC_ERR I2C_RCV_BLOCK: ACALL I2C_RCV_BYTE JB I2C_ERR, END_RCV_BLOCK MOV @BUF_PTR,A ;save byte INC BUF_PTR BUF_LEN, ACK_RCV_BYTE DJNZ MOV T2DAT. #80H :send NACK ACALL WAIT_ATN TNB DRDY, I2C BASIC ERR END_RCV_BLOCK: RET ; *MPF::::I2C::I2C_BASI.ASM:WAIT_ATN============= ;* FUNCTION NAME: WAIT_ATN ; * PACKAGE: I2C ; * DESCRIPTION: ;* The WAIT_ATN function waits for the ATN bit to be set. * The function is left if the ATN bit is set or if the TIME_ERR bit is set. The TIME_ERR bit indicates that a ^{\star} ``` ## EIE/AN91007 ``` bus timeout has occurred. If the 8xC751 enters this ; * function as a master, the RECOVER bit is set, indicating that in case of a timeout, a bus recover action must be started. WAIT_ATN: JNB MASTER, WAIT SETB RECOVER WIAT: JB TIME_ERR, END_WAIT JNB ATN, WAIT END_WAIT: CLR RECOVER RET ; *MPF:::I2C::I2C_BASI.ASM:TI_INT================= ; * FUNCTION NAME: TI_INT I2C ; * PACKAGE: ; * DESCRIPTION: The TI_INT handles the timeout interrupt. It is entered when a time out occurs (during wAIT_ATN). The function is placed here to be sure that it is linked when placed in a library. ;*EMP==================== TI_INT: CLR 092H ACALL SCL_DELAY SETB 092H JNB RECOVER, RET_INT SETB SETB SCL JNB SCL, RET_INT MOV BUS_ERR_CLKS, #9 ;SCL = 1 RETRY_LOOP: CLR SCL ACALL SCL_DELAY SETB SCL ACALL SCL_DELAY SDA, MAKE STOP ;if SDA = 1 make stop JTR . DJNZ BUS_ERR_CLKS, RETRY_LOOP RETI MAKE_STOP: CLR SCL NOP CLR SDA ACALL SCL_DELAY SETB SCL ACALL SCL_DELAY SETB SDA ; make stop condition ACALL SCL DELAY SETB BUS_RECOVERED RET INT: RETI SCL_DELAY: ;delay of 9 periods (>= 6 micro sec.) NOP ; ACALL(2) + 5 NOP (4) + RET (2) NOP NOP NOP NOP HISTORY ;* ;* 03-07-91 J.C. Pijnenburg original version END ``` ## EIE/AN91007 ``` $TITLE(I2C_Test_Device command) SOURCE FILE : I2C_TDEV.ASM PACKAGE : I2C * INCLUDES SNOLTST $INCLUDE (I2C_DATA.GLO) STATEM ;* GLOBAL REFERENCES EXTRN CODE(I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* : *------ PUBLIC _I2C_TEST_DEVICE ; * LOCAL SYMBOL DECLARATIONS TEST_DEVICE_MASK EQU 80H ;REP_STRT_BLK1 = 0 ; RWN_BLK1 = 0 (WRITE) ; RWN___ ; ; ADDR2 = U (--) ; ADDR2_SUB = 0 (--) ; BLOCK2 = 0 (NO) ; BLK2 = 0 (--) :T DEVICE = 1 * CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_TDEV.ASM:I2C_TEST_DEVICE=========* * FUNCTION NAME: I2C_TEST_DEVICE ; * PACKAGE: T2C ; * DESCRIPTION: Address a slave , if ack received slave was present ; * PROTOCOL: <S><SLV_ADDR><W><A><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_TEST_DEVICE: I2C_CTRL, #TEST_DEVICE_MASK MOV AJMP I2C MESS HAND END ``` ## EIE/AN91007 ``` $TITLE(I2C_Write command) ;* SOURCE FILE : I2C_WRIT.ASM ;* PACKAGE : I2C ·* SDEBUG * INCLUDES ;*=================================== SNOLIST $INCLUDE (I2C_DATA.GLO) $LIST ;* GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) * GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_WRITE LOCAL SYMBOL DECLARATIONS WRITE_MASK EQU 00H ;REP_STRT_BLK1 = 0 (NO) (WRITE) ;RWN_BLK1 = 0 ;ADDR2 = 0 (NO) ;ADDR2_SUB = 0 (--) (NO) = 0 = 0 : BLOCK2 ; RWN_BLK2 ;RWN_BLK2 = 0 (--);REP_STRT_BLK2 = 0 (--) ;TEST_DEVICE = 0 ; *----- * CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_WRIT.ASM:I2C_WRITE============ ; * FUNCTION NAME: I2C WRITE ; * PACKAGE: I2C ; * DESCRIPTION: ;* Write n bytes to a slave device. ; * PROTOCOL: <S><SLV_ADDR><W><A><D0><A><D1><A>. .<Dn-1><A><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) BUF_LEN1 (number of bytes (n) to trx.) * (ptr to transmit buffer) BUF_PTR1 ;* OUTPUT: I2C_ERROR byte (bit addressable) : *EMP================================== _I2C_WRITE: MOV I2C_CTRL, #WRITE_MASK AJMP I2C_MESS_HAND END ``` ### EIE/AN91007 ``` $TITLE(I2C_Write_Sub command) ;*============** SOURCE FILE : I2C_WSUB.ASM PACKAGE : I2C $DEBUG * INCLUDES ; *========== SNOTITEM $INCLUDE (I2C_DATA.GLO) $LIST GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) ;* GLOBAL FUNCTION DEFINITIONS * PUBLIC _I2C_WRITE_SUB ;* LOCAL SYMBOL DECLARATIONS * ; *============= WRITE_SUB_MASK EQU 00H ;REP_STRT_BLK1 = 0 (NO) ;RWN_BLK1 = 0 ;ADDR2 = 1 (WRITE) (YES) ;ADDK2 = 1 (1E5 ;ADDR2_SUB = 1 (YES ;BLOCK2 = 0 (NO) ;RWN_BLK2 = 0 (--) ;REP_STRT_BLK2 = 0 (--) (YES) ; TEST_DEVICE = 0 (--) CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_WSUB.ASM:I2C_WRITE_SUB============ ;* FUNCTION NAME: I2C WRITE SUB ; * PACKAGE: I2C ; * DESCRIPTION: Write a block of data (a length n) preceded by a sub address to a slave device. ; * PROTOCOL: <S><SLV_ADDR><W><A><SUB_ADDR><A><Da0><A><Da1><A>...<A> <Dan-1><A><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) BUF_LEN1 (number of bytes in block) (ptr to block ) (sub address) BUF_PTR1 I2C_ADDR2 ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_WRITE_SUB: MOV I2C_CTRL, #WRITE_SUB_MASK AJMP I2C_MESS_HAND END ``` ## EIE/AN91007 ``` $TITLE(I2C_Write_Sub_SWinc command) ; * SOURCE FILE : I2C_WSWI.ASM PACKAGE : I2C $DEBUG * INCLUDES SNOLITST $INCLUDE(I2C_DATA.GLO) $INCLUDE(I2C_DATA.LOC) $INCLUDE(REG751.H) $LIST * GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) * GLOBAL FUNCTION DEFINITIONS* ; *=================== PUBLIC _I2C_WRITE_SUB_SWINC PUBLIC _I2C_WRITE_MEMORY LOCAL SYMBOL DECLARATIONS WRITE_SUB_SWINC_MASK EQU 00CH WRITE_MEMORY_MASK EQU 02CH ;REP_STRT_BLK1 = 0 = 0 ; RWN_BLK1 (WRITE) ; ADDR2 = 1 (YES) ; ADDR2_SUB = 1 (YES) :BLOCK2 = 0 (NO) ; RWN_BLK2 = 0 or 1 (no blk2. used for delay/no delay) ;REP_STRT_BLK2 = 0 (--) ;TEST_DEVICE = 0 CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C DRIVER ; *MPF:::I2C::I2C_WSWI.ASM:I2C_WRITE_SUB_SWINC======== ;* FUNCTION NAME: I2C_WRITE_SUB_SWINC ; * PACKAGE: ; * DESCRIPTION: Transmit an I2C message, the message is split into sub messages. Each sub message transmits one byte. If the slave is an EEPROM a delay is generated after each sub message. The RWN_BLK2 is not used in the message handler (no block 2) and is therefore free to distinguish between write to EEPROM (1=delay) and other* (0= no delay) ;* PROTOCOL: <S><SLV_ADDR><W><A><SUB_ADDR><A><D0><A><P> if (RWN_BLK2) delay 40 ms ; * <S><SLV_ADDR><W><A><SUB_ADDR+1><A><D1><A><P> ; * if (RWN_BLK2) delay 40 ms if (RWN_BLK2) delay 40 ms <S><SLV_ADDR><W><A><SUB_ADDR+n-1><A><Dn-1><P> if (RWN_BLK2) delay 40 ms ``` ## EIE/AN91007 ``` ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) BUF_LEN1 (number of bytes (mess) to trx.)* BUF_PTR1 (ptr to transmit buffer) (sub address) I2C_ADDR2 ;* OUTPUT: I2C_ERROR byte (bit addressable) ;*EMP============= _I2C_WRITE_MEMORY: VOM I2C_CTRL, #WRITE_MEMORY_MASK SJMP SET_MESS_CNT _I2C_WRITE_SUB_SWINC: I2C_CTRL, #WRTIE_SUB_SWINC_MASK SET_MESS_CNT: MEM_MESS_LEN, I2C_MCB+1 MOV MOV I2C_MCB+1,#1 ;set BUF_LEN_1 = 1 SUB_MESS; I2C_MESS_HAND ACALL JB I2C_ERR, END_WSWI INC I2C_MCB+2 ;inc. BUFF_PTR_1 INC I2C_MCB+3 ;inc. SUB_ADDR JNB RWN_BLK2, NEXT MEM_DELAY_H, #EEPROM_PROG_DELAY MOV MOV ; 40 mS delay at 16MHz MEM_DELAY_L,#00 PROGRAM_DELAY: DINZ MEM_DELAY_L,$ DJNZ MEM_DELAY_H, PROGRAM_DELAY NEXT: D.TNZ MEM_MESS_LEN, SUB-MESS END_WSWI: END ``` ### EIE/AN91007 ``` $TITLE(I2C_Write_Sub_Write command) ================ SOURCE FILE : I2C_WSUW.ASM PACKAGE : I2C $DEBUG * INCLUDES SNOLIST $INCLUDE(I2C_DATA.GLO) SLIST * GLOBAL REFERENCES EXTRN CODE (12C_MESS_HAND) * GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_WRITE_SUB_WRITE LOCAL SYMBOL DECLARATIONS WRITE_SUB_WRITE_MASK EQU 1CH ;REP_STRT_BLK1 = 0 = 0 = 1 (WRITE) :RWN BLK1 ; ADDR2 (YES) (YES) ;ADDR2_SUB = 1 = 1 ;BLOCK2 (YES) (wRITE) ; RWN_BLK2 = 0 ;REP_STRT_BLK2 = 0 (NO) ;TEST_DEVICE = 0 ;*============* CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_WSUW.ASM:I2C_WRITE_SUB_WRITE========* ;* FUNCTION NAME: I2C_WRITE_SUB_WRITE ; * PACKAGE: ; * DESCRIPTION: Write 2 blocks of data (a and b, length n and m) preceded by a sub address into a single slave device ; * PROTOCOL: <S><SLV_ADDR><W><A><SUB_ADDR><A><Da0><A>..<A><Dan-1><A> <Db0><A>..<Dbm-1><A><P>* ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) BUF_LEN1 (number of bytes in block a) (ptr to block a) BUF_PTR1 I2C_ADDR2 (sub address) BUF LEN1 (number of bytes in block b) BUF_PTR1 (ptr to block b) ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_WRITE_SUB_WRITE: I2C_CTRL, #WRITE_SUB_WRITE_MASK MOV A.TMP I2C_MESS_HAND END ``` ## EIE/AN91007 ``` $TITLE(I2C_Write_Sub_Read command) ; * SOURCE FILE : I2C_WSUR.ASM : I2C * INCLUDES SNOLIST $INCLUDE(I2C_DATA.GLO) SLIST * GLOBAL REFERENCES ;*=========* EXTRN CODE(I2C_MESS_HAND) ;* GLOBAL FUNCTION DEFINITIONS * ;*======= PUBLIC _I2C_WRITE_SUB_READ ;*======================= LOCAL SYMBOL DECLARATIONS WRITE_SUB_READ_MASK EQU 7CH ;REP_STRT_BLK1 = 0 (NO) ;RWN_BLK1 = 0 ;ADDR2 = 1 (WRITE) ; ADDR2; sub = 1; BLOCK2 = 1 (YES) (YES) (YES) (READ) ;REP_STRT_BLK2 = 1 (YES) ;TEST_DEVICE = 0 CODE SEGMENT ;*================== T2C DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::12C::12C_WSUR.ASM:12C_WRITE_SUB_READ========== ;* FUNCTION NAME: I2C_WRITE_SUB_READ : * PACKAGE: I2C ; * DESCRIPTION: Write a block of data (a length n) preceded by a sub address, generate repeated start and read a second block of data (b length m) from the slave device ; * PROTOCOL: <S><SLV_ADDR><W><A><SUB_ADDR><A><Da0><A>...<A><DaN-1><A>* ; * <S><SLV_ADDR><R><A><Db0><A>..<A><Dbm-1><N><P> ; * ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: . . I2C_ADDR1 (slave address) BUF_LEN1 (number of bytes in block a) BUF_PTR1 (ptr to block a) I2C_ADDR2 (sub address) BUF_LEN1 (number of bytes in block b) (ptr to block b) BUF_PTR1 ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_WRITE_SUB_READ: I2C_CTRL, #WRITE_SUB_READ_MASK MOV AJMP I2C MESS HAND END ``` Philips Semiconductors Application note # I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ``` $TITLE(I2C_Write_Com_Write command) ;* SOURCE FILE : I2C_WCOW.ASM ;* PACKAGE : I2C ;*=================================== SDEBUG * INCLUDES $NOLIST $INCLUDE(I2C_DATA.GLO) GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_WRITE_COM_WRITE LOCAL SYMBOL DECLARATIONS WRITE_COM_WRITE_MASK EQU 10H ;REP_STRT_BLK1 = 0 (NO) :RWN BLK1 = 0 (WRITE) = 0 : ADDR2 (NO) ;ADDR2_SUB = 0 (--) ; BLOCK2 = 1 (YES) ; RWN_BLK2 = 0 (WRITE) ;REP_STRT_BLK2 = 0 ;TEST_DEVICE CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_WCOW.ASM:I2C_WRITE_COM_WRITE==========* ; * FUNCTION NAME: I2C_WRITE_COM_WRITE ; * PACKAGE: ;* DESCRIPTION: Write a 2 blocks of data (a,b length n,m) in a single message to a slave device another slave device. ; * PROTOCOL: <S><SLV_ADDR1><W><A><Da0><A><Da1><A>...<A><Dan-1><A> <Db0><A><Db1><A>..<A><Dbm-1><A><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable);* Message control block I2C_MCB, containing: I2C_ADDR1 (slave address first device) BUF LEN1 (number of bytes in block a) (ptr to block a) BUF_PTR1 BUF_LEN1 (number of bytes in block b) BUF_PTR1 (ptr to block b) ;* OUTPUT: I2C_ERROR byte (bit addressable) ;*EMP========* _I2C_WRITE_COM_WRITE: I2C_MCB+5, I2C_MCB+4 MOV I2C_MCB+4, I2C_MCB+3 VOM I2C_CTRL, #WRITE_COM_WRITE_MASK AJMP I2C_MESS_HAND END ``` **EIE/AN91007** ``` $TITLE(I2C_Write_Rep_Write command) SOURCE FILE : I2C_WREW.ASM PACKAGE : I2C SDEBUG * INCLUDES SNOLIST $INCLUDE(I2C_DATA.GLO) $LIST * GLOBAL REFERENCES EXTRN CODE(I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_WRITE_REP_WRITE LOCAL SYMBOL DECLARATIONS WRITE_REP_WRITE_MASK EQU 54H ;REP\_STRT\_BLK1 = 0 (NO) ;RWN_BLK1 = 0 (NO);RWN_BLK1 = 0 (WRITE);ADDR2 = 1 (YES) ;ADDR2_SUB = 0 ;BLOCK2 = 1 ;RWN_BLK2 = 0 (NO) (YES) (WRITE) (YES) CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_WREW.ASM:I2C_WRITE_REP_WRITE========= ; * FUNCTION NAME: I2C_WRITE_REP_WRITE ; * PACKAGE: ; * DESCRIPTION: Write a block of data (a length n) to a slave device, sent repeated start and write a block (b length m) to another slave device. ; * PROTOCOL: <S><SLV\_ADDR1><W><A><Da0><A><Da1><A> . . <A><Dan-1><A> <S><SLV_ADDR2><W><A><Db0><A><Db1><A>..<A><Dbm-1><N><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address first device) BUF_LEN1 (number of bytes in block a) BUF_PTR1 (ptr to block a) I2C_ADDR2 (slave address second device) BUF_LEN1 (number of bytes in block b) (ptr to block b) BUF_PTR1 ; * OUTPUT: I2C_ERROR byte (bit addressable) I2C WRITE REP WRITE: MOV I2C_CTRL, #WRITE_REP_WRITE_MASK A.TMP I2C MESS HAND END ``` # **EIE/AN91007** ``` $TITLE(I2C_Write_Rep_Read command) SOURCE FILE : I2C_WRER.ASM PACKAGE : I2C SDEBUG INCLUDES SNOLIST $INCLUDE(I2C_DATA.GLO) SLIST GLOBAL REFERENCES EXTRN CODE(I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_WRITE_REP_READ LOCAL SYMBOL DECLARATIONS WRITE_REP_READ_MASK EQU 74H ;REP_STRT_BLK1 = 0 (NO) = 0 :RWN BLK1 (WRITE) ; ADDR2 = 1 (YES) ; ADDR2_SUB = 0 (NO) ; BLOCK2 = 1 (YES) :RWN BLK2 = 1 (READ) ; REP_STRT_BLK2 = 1 (YES) ;TEST_DEVICE = 0 ; *===========* * CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_WRER.ASM:I2C_WRITE_REP_READ========== ; * FUNCTION NAME: I2C_WRITE_REP_READ ; * PACKAGE: ;* DESCRIPTION: Write a block of data (a length n) to a slave device, sent repeated start and read a block (b length m) from another slave device. ;* PROTOCOL: <S><SLV_ADDR1><W><A><Da0><A><Da1><A> . . <A><Dan-1><A> <S><SLV_ADDR2><R><A><Db0><A><Db1><A>..<A><Dbm-1><N><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address first device) BUF_LEN1 (number of bytes in block a) BUF_PTR1 (ptr to block a) I2C_ADDR2 (slave address second device) BUF LEN1 (number of bytes in block b) BUF_PTR1 (ptr to block b) ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_WRITE_REP_READ: MOV I2C_CTRL, #WRITE_REP_READ_MASK A.TMP I2C_MESS_HAND END ``` Philips Semiconductors Application note # I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers EIE/AN91007 ``` STITLE(I2C_Read command) SOURCE FILE : I2C_READ.ASM PACKAGE : I2C SDEBUG * INCLUDES SNOLTST $INCLUDE(I2C_DATA.GLO) SLIST * GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) * GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_READ PUBLIC _I2C_READ_STATUS ; *----- LOCAL SYMBOL DECLARATIONS READ_MASK EQU 02H ;REP_STRT_BLK1 = 0 (NO) = 1 :RWN BLK1 (READ) ; ADDR2 = 0 (NO) ;ADDR2_SUB = 0 ;BLOCK2 = 0 ;RWN_BLK2 = 0 (--) (NO) (--) ;REP_STRT_BLK2 = 0 ; TEST_DEVICE CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_READ.ASM:I2C_READ============== ;* FUNCTION NAME: I2C Read a block of data from a slave device (READ) or read* a single byte from a slave device (READ_STATUS) <S><SLV_ADDR><R><A><D0><A><D1><A>...<A><Dn-1><N><P> <S><SLV_ADDR><R><A><STATUS><N><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) (number of bytes in block ) BUF_LEN1 BUF_PTR1 (ptr to store status) ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_READ_STATUS: I2C_MCB+2, II2C_MCB+1 MOV MOV I2C_MCB+1,#1 ;buffer length = 1 _i2C_READ: I2C_CTRL, #READ_MASK MOV I2C MESS HAND AJMP END ``` ### EIE/AN91007 ``` $TITLE(I2C_Read_Sub command) ;* SOURCE FILE : I2C_RSUB.ASM PACKAGE : I2C * INCLUDES $NOLIST $INCLUDE(I2C_DATA.GLO) SLIST * GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_READ_SUB LOCAL SYMBOL DECLARATIONS READ_SUB_MASK EQU OFH ;REP_STRT_BLK1 = 1 (YES) ;RWN_BLK1 = 1 (READ) ; RWN_BLACK; ; ADDR2 = 1 ; ADDR2_SUB = 1 ; BLOCK2 = 0 (YES) (YES) (NO) (--) ;REP_STRT_BLK2 = 0 (--) :TEST DEVICE = 0 CODE SEGMENT I2C_DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_RSUB.ASM:I2C_READ_SUB============= ;* FUNCTION NAME: I2C_READ_SUB ; * PACKAGE: I2C ; * DESCRIPTION: Read a block of data (a length n) preceded by a sub address from a slave device. ;* PROTOCOL: <S><SLV_ADDR><W><A><SUB_ADDR><A><S><SLV_ADDR><R><A> <Da0><A><Da1><A>. . <A><Dan-1><A><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C_ADDR1 (slave address) BUF_LEN1 (number of bytes in block ) BUF PTR1 (ptr to block ) I2C_ADDR2 (sub address) ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_READ_SUB: MOV I2C_CTRL, #READ_SUB_MASK AJMP I2C_MESS_HAND END ``` #### EIE/AN91007 ``` $TITLE(I2C_Read_Rep_Write command) SOURCE FILE : I2C_RREW.ASM PACKAGE : I2C ; *===-- * INCLUDES ;*========= SNOLIST $INCLUDE(I2C_DATA.GLO) SLIST * GLOBAL REFERENCES EXTRN CODE(I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_READ_REP_WRITE LOCAL SYMBOL DECLARATIONS READ_REP_WRITE_MASK EQU 56H ;REP_STRT_BLK1 = 0 (NO) :RWN BLK1 = 1 (READ) ; ADDR2 = 1 (YES) ;ADDR2_SUB = 0 (NO) ;BLOCK2 = 1 (YES) ; RWN BLK2 = 0 (WRITE) ;REP_STRT_BLK2 = 1 (YES) ;TEST_DEVICE = 0 (--) CODE SEGMENT ; * ----- I2C_DRIVER SEGMENT CODE RSEG I2C DRIVER ; *MPF:::I2C::I2C_RREW.ASM:I2C_READ_REP_WRITE=========* * FUNCTION NAME: I2C_READ_REP_WRITE ; * PACKAGE: T2C ; * DESCRIPTION: Read a block of data (a length n) from a slave device, sent repeated start and write a block (b length m) to another slave device. ;* PROTOCOL: <S><SLV_ADDR1><R><A><Da0><A><Da1><A>..<A><Dan-1><N> <S><SLV_ADDR2><W><A><Db0><A><Db1><A>..<A><Dbm-1><A><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: I2C ADDR1 (slave address first device) BUF_LEN1 (number of bytes in block a) (ptr to block a) BUF_PTR1 I2C_ADDR2 (slave address second device) (number of bytes in block b) BUF_LEN1 (ptr to block b) BUF_PTR1 ; * OUTPUT: I2C_ERROR byte (bit addressable) _I2C_READ_REP_WRITE: I2C_CTRL, #READ_REP_WRITE_MASK AJMP I2C_MESS_HAND END ``` Philips Semiconductors Application note # I<sup>2</sup>C driver routines for 8XC751/2 microcontrollers ### EIE/AN91007 ``` $TITLE(I2C_Read_Rep_Read command) , * SOURCE FILE : 12C_RRER.ASM PACKAGE : 12C $DEBUG * INCLUDES ;*========= SNOLIST $INCLUDE(I2C_DATA.GLO) $LIST GLOBAL REFERENCES EXTRN CODE (I2C_MESS_HAND) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_READ_REP_READ LOCAL SYMBOL DECLARATIONS READ_REP_READ_MASK EQU 076H ; REP_STRT_BLK1 = 0 (NO) ; RWN_BLK1 = 1 (READ) ; ADDR2 = 1 (YES) (NO) ; ADDR2_SUB = 0 ;BLOCK2 = 1 (YES) ; RWN_BLK2 = 1 (READ) ; REP\_STRT\_BLK2 = 1 (YES) (--) ;TEST_DEVICE = 0 CODE SEGMENT I2C DRIVER SEGMENT CODE RSEG I2C_DRIVER ; *MPF:::I2C::I2C_RRER.ASM:I2C_READ_REP_READ==========* ;* FUNCTION NAME: I2C_READ_REP_READ ; * PACKAGE: I2C ; * DESCRIPTION: Read a block of data (a length n) from a slave device, sent repeated start and read a block (b length m) from ' another slave device. ;* PROTOCOL: <S><SLV_ADDR1><R><A><Da0><A><Da1><A>...<A><Dan-1><N> <S><SLV_ADDR2><R><A><Db0><A><Db1><A>..<A><Dbm-1><N><P> ;* INPUT: Message control byte I2C_CTRL (bit addressable) Message control block I2C_MCB, containing: (slave address first device) I2C ADDR1 BUF_LEN1 (number of bytes in block a) BUF PTR1 (ptr to block a) (slave address second device) I2C_ADDR2 BUF LEN1 (number of bytes in block b) BUF_PTR1 (ptr to block b) ;* OUTPUT: I2C_ERROR byte (bit addressable) _I2C_READ_REP_READ: 12C_CTRL, #READ_REP_READ_MASK MOV A.TMP I2C_MESS_HAND END ``` EIE/AN91007 # I<sup>2</sup>C Slave routines ``` $TITLE(I2C_SLAVE) ; * , * SOURCE FILE : I2C_SLAV.ASM PACKAGE : I2C **================== SDEBUG ;*================== ,* INCLUDES $NOLIST $INCLUDE (I2C_DATA.GLO) SINCLUDE (REG751.H) $LIST * GLOBAL REFERENCES EXTRN CODE(I2C_TRX_BYTE) EXTRN CODE (I2C_RCV_BYTE) EXTRN CODE (I2C_RCV_ADDR) EXTRN CODE (ADDR_COMPARE) GLOBAL FUNCTION DEFINITIONS* PUBLIC _I2C_SLV_TRX PUBLIC I2C SLV RCV PUBLIC ADDR_RECOG LOCAL SYMBOL DECLARATIONS SLV_BUF_PTR_W SET R1 BIT_CNT SET R3 I2C_RELEASE ; *MPF:::I2C_SLAVE======================== ; * FUNCTION NAME: 12C I2C_SLAVE_ROUTINES ;* DESCRIPTION: ; * DESCRIPTION: This file contains an example of how to make a slave transmitter and slave receiver function. The slave transmitter functions transmits byte from a buffer, while the slave receiver routine receives bytes into a buffer. The buffer pointer is loaded during the I2C_INIT routine. * INTERRUPT CODE SEGM: IIC * CSEG AT 023H PUSH ACC PUSH PSW MOV PSW, #8 AJMP ADDR_RECOG CODE SEGMENT I2C DRIVER SEGMENT CODE RSEG I2C_DRIVER ``` #### EIE/AN91007 ``` ; *MPF:::I2C::I2C_SLAV.ASM:I2C_ADDR_RECOG=============== ; * FUNCTION NAME: I2C ADDR RECOG * PACKAGE NAME T2C ; * DESCRIPTION: If an I2C interrupt occurs, and the STR bit is set, I2C_ADDR_RECOG receives the incoming slave address. If its own slave address is recognized, the slave receiver or slave transmitter routine (depending on the R/WN bit) is called ;* OUTPUT: I2C_ERROR byte (bit addressable) ADDR_RECOG: MOV I2CON, #C_STRT ACALL I2C RCV ADDR JB I2C_ERR, EXIT_SLV_AD ACALL ADDR_COMPARE EXIT_SLV_AD: CLR I2C_ERR MOV I2CON, #I2C_RELEASE POP POP ACC ; *MPF:::I2C::I2C_SLAV.ASM:I2C_SLV_TRX================ ;* FUNCTION NAME: I2C_SLV_TRX * PACKAGE NAME . T2C ;* DESCRIPTION: After the SLV_ADDR/W is received, the I2C_SLV_TRX transmits a byte from the slave buffer. The pointer to this buffer is loaded during the I2C_INIT function.* If an acknowledge is received, the pointer is incremented and the next byte is transmitted. The function is exit on reception of a NACK. Normally the slave routines are entered through an I2C* interrupt, but if the 8xC751 loses arbitration during * the slave address and it recognizes its own slave ; * , * address/W, the I2C_SLV_TRX function is entered at XXXX* ;* PROTOCOL: <S><SLV_ADDR><W><D0><A><D1><A>...<A><Dn><N><P> ;* REGISTER USAGE : Register bank 1, is used during the I2C routines, it contains no static data, and is free for the user outside the I2C routines ;* OUTPUT: I2C_ERROR byte (bit addressable) I2C_SLV_TRX: SLV_BUF_PTR_W, SLV_BUF_PTR S_TRX: MOV A, @SLV_BUF_PTR_W ACALL I2C_TRX_BYTE JB I2C_ERR, EXIT_SLV_TRX JB NO_ACK, EXIT_SLV_TRX INC SLV_BUF_PTR_W AJMP S_TRX EXIT_SLV_TRX: ``` # EIE/AN91007 ``` ; *MPF:::I2C::I2C_SLAV.ASM:I2C_SLV_RCV============* ;* FUNCTION NAME: I2C SLV RCV * PACKAGE NAME: T2C ; * DESCRIPTION: After the SLV_ADDR/R is received, the I2C_SLV_RCV receives a byte into the slave buffer. The pointer to this buffer is loaded during the I2C_INIT function. After the byte is received, and acknowledge is send, the pointer is incremented and the next byte is received. The function is exit on if a start condition is detected. Normally the slave routines are entered through and I2C* interrupt, but if the 8xC751 loses arbitration during the slave address and it recognizes its own slave address/R, the I2C_SLV_RCV function is entered at xx ;* PROTOCOL: <S><SLV_ADDR><R><D0><A><D1><A>...<A><Dn><A><P> ;* REGISTER USAGE : Register bank 1, is used during the I2C routines, it contains no static data, and is free fr the user outside the I2C routines ; * INPUT: -- ; * OUTPUT: I2C_ERROR byte (bit addressable) I2C-SLV_RCV: SLV_BUF_PTR_W, SLV_BUF_PTR MOV S_RCV: ACALL I2C_RCV_BYTE JB 12C_ERR,EXIT_SLV_RCV MOV @SLV_BUF_PTR_WQ, A ;save byte MOV I2DAT,#0 JNB ATN,$ JNB DRDY, EXIT_SLV_RCV INC SLV_BUF_PTR_W AJMP S_RCV EXIT_SLV_RCV: HISTORY ;* 21-05-91 J.C. Pijnenburg original version END ``` EIE/AN91007 # I2C\_MAC.DEF ``` #* DEFINE (I2C_INIT(Own_Slv_Addr,Slv_Buf_Addr,Retry)) MOV OWN_SLV_ADDR, #%Own_Slv_Addr MOV SLV_BUF_PTR, #%Slv_Buf_Addr MOV I2C_MCB, ACALL _I2C_INIT #* DEFINE (I2C_TEST_DEVICE(Slv_Addr)) MOV I2C_MCB, #%Slv_Addr ACALL _I2C_TEST_DEVICE #* DEFINE (I2C_WRITE(Slv_Addr,Count,Source_Ptr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count MOV I2C_MCB+2, #%Source_Ptr ACALL _I2C_WRITE #* DEFINE (I2C_WRITE_SUB(Slv_Addr,Count,Source_Ptr,Sub_Addr)) MOV I2C_MCB , #%Slv_Addr MOV I2C_MCB+1, #%Count MOV I2C_MCB+2, #%Source_Ptr MOV I2C_MCB+3, #%Sub_Addr ACALL _I2C_WRITE_SUB #* DEFINE (I2C_WRITE_SUB_SWINC(Slv_Addr,Count,Source_Ptr,Sub_Addr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count MOV I2C_MCB+2, #%Source_Ptr MOV I2C_MCB+3, #%Sub_Addr ACALL _I2C_WRITE_SUB_SWINC #* DEFINE (I2C_WRITE_MEMORY(Slv_Addr,Count,Source_Ptr,Sub_Addr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count MOV I2C_MCB+2, #%Source_Ptr MOV I2C MCB+3, #%Sub Addr ACALL _I2C_WRITE_MEMORY #* DEFINE (I2C_WRITE_SUB_WRITE(Slv_Addr,Count_1,Source_Ptr_1,Sub_Addr,Count_2,Source_Ptr_2)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Source_Ptr_1 MOV I2C_MCB+3, #%Sub_Addr MOV I2C_MCB+4, #%Count_2 MOV I2C_MCB+5, #%Source Ptr 2 ACALL _I2C_WRITE_SUB_WRITE %* DEFINE (I2C_WRITE_SUB_READ(Slv_Addr,Count_1,Source_Ptr,Sub_Addr,Count_2,Dest_Ptr)) MOV I2C_MCB , #%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Source_Ptr MOV I2C_MCB+3, #%Sub_Addr MOV I2C_MCB+4, #%Count_2 MOV I2C_MCB+5, #%Dest_Ptr ACALL _I2C_WRITE_SUB_READ ``` #### EIE/AN91007 ``` %* DEFINE (I2C_WRITE_COM_WRITE(Slv_Addr,Count_1,Source_Ptr_1,Count_2,Source_Ptr_2)) MOV I2C_MCB , #%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Source_Ptr_1 MOV I2C_MCB+3, #%Count_2 MOV I2C_MCB+4, #%Source_Ptr_2 ACALL _I2C_WRITE_COM_WRITE %* DEFINE (I2C_WRITE_REP_WRITE(Slv_Addr,Count_1,Source_Ptr_1,Sub_Addr,Count_2,Source_Ptr_2)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Source_Ptr_1 MOV I2C_MCB+3, #%Sub_Addr MOV I2C_MCB+4, #%Count_2 MOV I2C_MCB+5, #%Source_Ptr_2 ACALL _I2C_WRITE_REP_WRITE %* DEFINE (I2C_WRITE_REP_READ(Slv_Addr,Count_1,Source_Ptr,Sub_Addr,Count_2,Dest_Ptr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Source_Ptr MOV I2C_MCB+3, #%Sub_Addr MOV I2C_MCB+4, #%Count_2 MOV I2C_MCB+5, #%Dest_Ptr ACALL _I2C_WRITE_REP_READ %* DEFINE (I2C_READ(Slv_Addr,Count,Dest_Ptr)) MOV I2C_MCB , #%Slv_Addr MOV I2C_MCB+1, #%Count MOV I2C_MCB+2, #%Dest_Ptr ACALL I2C READ %* DEFINE (I2C_READ_STATUS(Slv_Addr,Dest_Ptr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Dest_Ptr ACALL _I2C_READ_STATUS %* DEFINE (I2C_READ_SUB(Slv_Addr,Count,Dest_Ptr,Sub_Addr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count MOV I2C_MCB+2, #%Dest_Ptr MOV I2C_MCB+3, #%Sub_Addr ACALL _I2C_READ_SUB %* DEFINE (I2C_READ_REP_READ(Slv_Addr,Count_1,Dest_Ptr_1,Sub_Addr,Count_2,Dest_Ptr_2)) MOV I2C_MCB , #%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Dest_Ptr_1 MOV I2C_MCB+3, #%Sub_Addr MOV I2C_MCB+1, #%Count_2 MOV I2C_MCB+2, #%Dest_Ptr_2 ACALL _I2C_READ_REP_READ %* DEFINE (I2C_READ_REP_WRITE(Slv_Addr,Count_1,Dest_Ptr,Sub_Addr,Count_2,Source_Ptr)) MOV I2C_MCB ,#%Slv_Addr MOV I2C_MCB+1, #%Count_1 MOV I2C_MCB+2, #%Dest_Ptr MOV I2C_MCB+3, #%Sub_Addr MOV I2C_MCB+1, #%Count_2 MOV I2C_MCB+2, #%Source_Ptr ACALL _I2C_READ_REP_WRITE ``` EIE/AN91007 # I2C PLM.H ``` 11 INCLUDE FILE: I2C_PLM.H /* PACKAGE: I2C */ GLOBAL FUNCTION PROTOTYPES I2C_INIT: PROCEDURE(Own_Slv_Addr,Slv_Buf_Addr,Retry) BIT EXTERNAL; DECLARE(Own_Slv_Addr,Slv_Buf_Addr,Retry) BYTE MAIN; END I2C_INIT; 12C_TEST_DEVICE: PROCEDURE(Slv_Addr) BIT EXTERNAL; DECLARE(Slv_Addr) BYTE MAIN; END I2C_TEST_Device I2C_WRITE: PORCEDURE(Slv_Addr,Count,Source_Ptr) BIT EXTERNAL; DELCARE(Slv_Addr,Count,Source_Ptr) BYTE MAIN; END I2C_WRITE; I2C_WRITE_SUB; PROCEDURE(Slv_Addr,Count,Source_Ptr,Sub_Addr) BIT EXTERNAL; DECLARE(Slv_Addr,Count,Source_Ptr,Sub_Addr) BYTE MAIN; END I2C_WRITE_SUB; I2C_WRITE_SUB_SWINC: PROCEDURE(Slv_Addr,Count,Source_Ptr,Sub_Addr) BIT EXTERNAL; DECLARE(Slv_Addr,Count,Source_Ptr,Sub_Addr) BYTE MAIN; END 12C_WRITE_SUB_SWINC; I2C_WRITE_MEMORY: PROCEDURE(Slv_Addr,Count,Source_Ptr,Sub_Addr) BIT EXTERNAL; DECLARE(Slv_Addr,Count,Source_Ptr,Sub_Addr) BYTE MAIN; END I2C_WRITE_MEMORY; 12C_WRITE_SUB_WRITE: PROCEDURE(Slv_Addr,Count_1,Source_Ptr_1,Sub_Addr,Count_2,Source_Ptr_2) BIT EXTERNAL; DECLARE(Slv_Addr,Count-1,Source_Ptr_1,Sub_Addr,Count_2,Source_Ptr_2) BYTE MAIN; END I2C_WRITE_SUB_WRITE; I2C_WRITE_SUB_READ: PROCEDURE(Slv_Addr,Count_1,Source_Ptr,Sub_Addr,Count,Dest_Ptr) BIT EXTERNAL; DECLARE(Slv_Addr,Count_1,Source_Ptr,Sub_Addr,Count,Dest_Ptr) BYTE MAIN; END I2C_WRITE_SUB_READ; I2C_WRITE_COM_WRITE: PROCEDURE(Slv_Addr,Count_1,Source_Ptr_1,Count_2,Source_Ptr_2) BIT EXTERNAL; DECLARE(Slv_Addr,Count_1,Source_Ptr_1,Count_2,Source_Ptr_2) BYTE MAIN; END I2C_WRITE_COM_WRITE; I2C_WRITE_REP_WRITE: PROCEDURE(Slv_Addr,Count_1,Source_Ptr_1,Sub_Addr,Count_2,Source_Ptr_2) BIT EXTERNAL; DECLARE(Slv_Addr,Count_1,Source_Ptr_1,Sub_Addr,Count_2,Source_Ptr_2) BYTE MAIN; END I2C_WRITE_REP_WRITE; I2C_WRITE_REP_READ: PROCEDURE(Slv_Addr,Count_1,Source_Ptr,Sub_Addr,Count_2,Dest_Ptr) BIT EXTERNAL; DECLARE(Slv_Addr,Count_1,Source_Ptr,Sub_Addr,Count_2,Dest_Ptr) BYTE MAIN; END I2C_WRITE_REP_READ; I2C_READ: PROCEDURE(Slv_Addr,Count,Dest_Ptr) BIT EXTERNAL; DECLARE(Slv_Addr,Count,Dest_Ptr) BYTE MAIN; END I2C_READ; I2C_READ_STATUS: PROCEDURE(Slv_Addr,Dest_Ptr) BIT EXTERNAL; DECLARE(Slv_Addr, Dest_Ptr) BYTE MAIN; END I2C_READ_STATUS; I2C_READ_SUB: PROCEDURE(Slv_Addr,Count,Dest_Ptr,Sub_Addr) BIT EXTERNAL; DECLARE(Slv_Addr,Count,Dest_Ptr,Sub_Addr) BYTE MAIN; END I2C_READ_SUB; I2C_READ_REP_READ: PROCEDURE(Slv_Addr,Count_1,Dest_Ptr_1,Sub_Addr,Count_2,Dest_Ptr_2) BIT EXTERNAL; DECLARE(Slv_Addr,Count_1,Dest_Ptr_1,Sub_Addr,Count_2,Dest_Ptr_1) BYTE MAIN; END I2C_READ_REP_READ; I2C_READ_REP_WRITE: PROCEDURE(Slv_Addr,Count_1,Dest_Ptr_1,Sub_Addr,Count_2,Source_Ptr) BIT EXTERNAL; DECLARE(Slv_Addr,Count_1,Dest_Ptr_1,Sub_Addr,Cout_2,Source_Ptr) BYTE MAIN; END I2C_READ_REP_WRITE; ``` EIE/AN91007 # I2C\_C.H ``` INCLUDE_FILE: I2C_C.H PACKAGE: I2C GLOBAL FUNCTION PROTOTYPES bit I2C_INIT(char Won_Slv_Addr,char *Slv_Buf_Ptr,char Retry); bit I2C_TEST_Device(char Slv_Addr); bit I2C_WRITE(char Slv_Addr, char Count, shar *Source_Ptr); bit I2C_WRITE_SUB(char Slv_Addr, char Count, char *Source_Ptr, char Sub_Addr); bit I2C WRITE SUB_SWINC(char Slv_Addr,char Count,char *Source_Ptr,char Sub_Addr); bit I2C_WRITE_MEMORY(char Slv_Addr,char Count,char *Source_Ptr,char Sub_Addr); bit I2C_WRITE_SUB_WRITE(char Slv_Addr,char Count_1,char *Source_Ptr_1,char Sub_Addr,char Count_2,char *Source_Ptr_2); bit I2C_WRITE_SUB_READ(char Slv_Addr, char Count_1, char *Source_Ptr, char Sub_Addr, char Count, char *Dest_Ptr); bit I2C_WRITE_COM_WRITE(char Slv_Addr,char Count_1,char *Source_Ptr_1,char Count_2,char *Source_Ptr_2); bit I2C_WRITE_REP_WRITE(char Slv_Addr,char Count_1,char *Source_Ptr_1,char Sub_Addr,char Count_2,char *Source_Ptr_2); bit I2C_WRITE_REP_READ(char Slv_Addr,char Count_1,char *Source_Ptr,char Sub_Addr,char Count_2,char *Dest_Ptr); bit I2C_READ(char Slv_Addr,char Count,char *Dest_Ptr); bit I2C_READ_STATUS(char Slv_Addr,char *Dest_Ptr); bit I2C_READ_SUB(char Slv_Addr,char Count,char *Dest_Ptr,char Sub_Addr); bit I2C_READ_REP_READ(char Slv_Addr,char Count_1,char *Dest_Ptr_1,char Sub_Addr,char Count_2,char *Dest_Ptr_2); bit I2C_READ_REP_WRITE(char Slv_Addr,char Count_1,char *Dest_Ptr_1,char Sub_Addr,char Count_2,char *Source_Ptr); ``` EIE/AN91007 # **DEMO\_ASM.ASM** ``` $TITLE(Assembly example program) SOURCE FILE : DEMO_ASM.ASM PACKAGE : I2C ;* Hours and minutes will be displayed on LCD display ;* Dot between hours and minutes will blink $DEBUG SNOLIST * INCLUDES $INCLUDE(I2C_DATA.GLO) $INCLUDE(I2C_MAC.DEF) SLIST * GLOBAL FUNCTION DEFINITIONS* EXTRN CODE (_I2C_INIT) EXTRN CODE (_I2C_WRITE) EXTRN CODE (_I2C_READ_SUB) ;*------ LOCAL DATA DEFINITIONS RAMVAR SEGMENT DATA ; Segment for variables SEGMENT DATA ;Segment for variables SEGMENT CODE ;Segment for application program * LOCAL SYMBOL DEFINITIONS CLOCK_ADR EQU 0A2H ;Address of PCF8583 ;Sub address for reading time ;Address of PCF8577 CL_SUB_ADR EQU 01H LCD_ADR EQU 74H * DATA SEGMENT RSEG RAMVAR :Buffer for I2C strings TIME_BUFFER: DS 4 LCD_BUFFER: DS 5 RSEG STACK STACK_DATA: DS 10 ;*================== * CODE SEGMENT CSEG AT 00 AJMP APPL MAIN RSEG USER APPL_MAIN: MOV SP,#STACK_DATA-1 ;Pointer to segment table MOV DPTR, #LCD_TAB MOV LCD_BUFFER, #00 ;Ctrl word for LCD driver %I2C_INIT(22h,TIME_BUFFER,0) ;Init I2C interface CLR A ;Prepare buffer MOV TIME_BUFFER, A ;for clock int. MOV TIME_BUFFER+1A %I2C_WRITE(CLOCK_ADR, 2, TIME_BUFFER) ; Initialize clock REPEAT: %12C_READ_SUB(CLOCK_ADR, 4, TIME_BUFFER, CL_SUB_ADR) ``` July 1991 265 ;Read time # EIE/AN91007 ``` Time has been read. Order: hundreds of sec's, sec's, min's and hr's ;Mask of hour counter MOV A, TIME_BUFFER+3 ANL A, #3Fh MOV TIME_BUFFER+3, A ACALL CONVERT ;Convert time data to ;LCD segment data Check if dot has to be switched on ORL LCD_BUFFER+3,#01h If 1sb of seconds is '0', then switch on dp MOV A, TIME_BUFFER+1 ;Get seconds RRC A JC PROCEED ORD LCD_BUFFER+1,#01 ;Switch on dp Display new time PROCEED: %12C_WRITE(LCD_ADR,5,LCD_BUFFER) SJMP REPEAT ;Read new time CONVERT converts BCD data of time to segment data ;R0 is pointer ;Get hours CONVERT: MOV RO, #LCD_BUFFER+1 MOV A, TIME_BUFFER+3 SWAP A ;Swap nibbles ;Convrt 10's of hours ACALL LCD_DATA MOV A, TIME_BUFFER+3 ;Convert hours ACALL LCD_DATA MOV A, TIME_BUFFER+2 ;Get minutes SWAP A ACALL LCD_DATA ;Convrt 10's of minut MOV A, TIME_BUFFER+2 ACALL LCD_DATA :Convert minutes RET LCD_DATA gets data from segment table and stores it in LCD_BUFFER LCD_DATA: ANL A, #0FH ;Mask off LS-nibble MOVC A, @A+DPTR ;Get segment data MOV @RO, A ;Save segment data RET Conversion table for LCD LCD_TAB: DB OFCH, 60H, ODAH ;'0','1','2' ; '3', '4', '5' ; '6', '7', '8' ; '9' DB 0F2H,66H,0B6H DB 3EH, 0EOH, 0FEH DB 0E6H END ``` EIE/AN91007 # **DEMO PLM.PLM** ``` $OPTIMIZE(4) $DEBUG $CODE /* SOURCE FILE : DEMO_PLM.PLM /* PACKAGE : I2C /* Hours and minutes will be displayed on LCD display /* Dot between hours and minutes will blink Demo_plm: Do; /* INCLUDES SNOTTST $INCLUDE(I2C_PLM.H) STITST /*==========*/ MATN Clock: Do; /* Variable and constand declarations */ Declare LCD_TAB(*) Byte Constant (0FCh, 60H, 0DAH, OF2H, 66H, OB6H, 3EH, OEOH, OFEH, OE6H); Declare Time_Buffer(4) Byte Main; Declare LCD_Buffer(5) Byte Main; Declare Tab_Point Word Main; Declare (LCD_Point, Time_Poiont) Byte Main; Declare Segment Based LCD_Point Byte Main; Declare Time Based Time_Point Byte Mian; Declare Tab_Value Based Tab_Point Byte Constant; Declare Clock_Adr Literally '0A2h'; Declare LCD_Adr Literally '74h'; Declare Cl_Sub_Adr Literally '01h'; Call I2C_INIT(22h,.Time_Buffer,0); LCD_Buffer(0)=0; /* LCD control word */ Time_Buffer(0)=0; Time_Buffer(1)=0; Call I2C_WRITE(Clock_Adr, 2, .Time_Buffer); /* Initialize clock */ Do While LCD Buffer(0)=0; /* Program loop */ Call I2C_READ_SUB(Clock_Adr, 4, .Time_Buffer, /* Get time */ Cl_Sub_Adr); LCD_Point=.LCD_Buffer(1); /* Init pointers */ Time_point=.Time_Buffer(3); Tab_Point=.LCD_Tab(0)+SHR(Time,4); /* 10-HR's */ Segment=Tab Value; LCD_Point=LCD_Point+1; Tab_Point=.LCD_Tab(0)+(Time AND 0FH); /* HR's */ Segment=Tab_Value; Time_Point=Time_Point-1; LCD_Point=LCD_Point+1; Tab_Point=.LCD_Tab+SHR(Time, 4); /* 10-MIN's */ Segment=(Tab_Value OR 01H); /* dp */ LCD Point=LCD Point+1; Tab_Point=.LCD_Tab+(Time AND 0FH); /* MIN's */ Segment=Tab Value: Time_Pont=.Time_Buffer(1); /* Check sec's for LCD_Point=.LCD_Buffer+1; If (Time AND 01H)>0 then Segment = (Segment OR 01H); Call I2C_WRITE(LCD_Adr, 5, .LCD_Buffer); /* Display time */ End: End Clock; End Demo_plm; ``` 267 July 1991 #### EIE/AN91007 # DEMO\_C.C ``` SOURCE FILE : DEMO C.C PACKAGE : I2C_DEMO /*MPP:::xxxxx==========*/ /* PACKAGE NAME: I2C_DEMO /* DESCRIPTION: This demo program reads the time from a PCF8583 clock*/ IC, and displays it to an LCD display (both available*/ /* at the I2C demoboard. Hours and minutes will be displayed on LCD display Dot between hours and minutes will blink INCLUDES /*=============*/ #include "I2C_C.H" /* LOCAL SYMBOL DECLARATIONS */ /*===========*/ #define Clock_Adr 0xA2 #define LCD Adr 0x74 #define Cl_Sub_Adr 0 \times 01 /*===========*/ LOCAL DATA DEFINITIONS rom char LCD_Tab[] = \{0xFC, 0x60, 0xDA, 0xF2, 0x66, 0xB6.0x3E,0xE0,0xFE,0xE6); /* MAIN /*===========*/ void main() *Tab_Ptr; rom char data char Time_Buffer[4]; data char data char LCD_Buffer[5]; data char *LCD_Ptr; I2C_INIT90x22,&Time_Buffer,0); LCD_Buffer[0]=0; /* LCD control word*/ Time_Buffer[0]=0: Time_Buffer[1]=0: I2C_WRITE(Clock_Adr,2,&Time_Buffer); /* Init clock*/ while (1) /* Program loop*/ I2C_READ_SUB(Clock_Adr, 4, &Time_Buffer, Cl_Sub_Adr); /* Get time*/ LCD_Ptr = &LCD_Buffer[1]; /* Init pointers*/ Time_Ptr = &Time_Buffer[3]; Tab_Ptr = (LCD_Tab+(*Time_Ptr >> 4)); /*10-HR's*/ *(LCD_Ptr++) = *Tab_Ptr; Tab_Ptr = (LCD_Tab+(*(Time_Ptr--) & 0x0F)); /* HR's*/ *(LCD_Ptr++) = *Tab_Ptr; Tab_Ptr = (LCD_Tab + (*Time_Ptr >> 4)); /* 10-MIN's*/ *LCD_Ptr++) = (*Tab_Ptr | 0x01); /* dp*/ Tab_Ptr = (LCD_Tab+(*Time_Ptr & 0x0F)); /* MIN's*/ *LCD_Ptr = *Tab_Ptr; Time_Ptr = &Time_Buffer[1]; /* Check sec's blinking*/ LCD_Ptr = &LCD_Buffer[1]; if ((*Time_Ptr & 0x01)>0) *LCD_Ptr = (*LCD_Ptr | 0x01); I2C_WRITE(LCD_Adr, 5, &LCD_Buffer); /* Display time*/ } ``` # Programming the I<sup>2</sup>C interface Author: Mitchell Kahn # Dr. Dobb's he Inter-Integrated Circuit Bus ("I<sup>2</sup>C Bus" for short) is a two-wire, synchronous, serial interface designed primarily for communication between intelligent IC devices. The I<sup>2</sup>C bus offers several advantages over "traditional" serial interfaces such as Microwire and RS-232. Among the advanced features of I<sup>2</sup>C are multimaster operation, automatic baud-rate adjustment, and "plugand-play" network extensions. Mention the I<sup>2</sup>C bus to a group of American engineers and you'll likely get hit with an abundance of blank stares. I say American engineers because until recently the I<sup>2</sup>C bus was primarily a European phenomenon. Within the last year, however, interest in I<sup>2</sup>C in the United States has risen dramatically. Embedded systems designers are realizing the cost, space, and power savings afforded by robust serial interchip protocols. The idea of serial interconnect between integrated circuits is not new. Many semiconductor vendors offer devices designed to "talk" via serial links with other processors. Current examples include Microwire (National Semiconductor), SPI (Motorola), and most recently Echelon's Neuron chips. In all cases, the goal is the same: to reduce the wiring and pincount necessary for a parallel data bus. It simply does not make Mitch is a senior strategic development engineer for Intel and can be contacted at 5000 W. Chandler Blvd., Chandler, AZ 85226 or at mkahn@sedona. intel.com. economic sense to route a full-speed parallel bus to a slow peripheral. Unfortunately for most serial-buscapable devices, the choice of a bus protocol will dictate the CPU architecture. For example, only two CPU architectures implement an on-chip I<sup>2</sup>C port. If your choice of architecture precludes use of these architectures, then your only option is to implement the protocol in software. The software implementation of the I<sup>2</sup>C protocol discussed in this article came about as a result of an implicit challenge during a staff meeting. One of our managers proposed that we hire a consultant to write a software I<sup>2</sup>C driver for the Intel 80C186EB embedded processor. Being somewhat new to the group, I took exception (although not verbally!) to his suggestion. A weekend of intense hacking later, I presented the first prototype of the driver. My reward? I got to write a generic version of the driver for general distribution. #### Design Trade-offs Three distinct tasks are involved in implementing the I2C protocol: watching the bus, waiting for a specific amount of time, and driving the bus. This became apparent when I flowcharted 1 byte of a typical bus transaction; see Figure 1. The time delays associated with creating the bus waveforms would normally have been relegated to the 80C186EB's on-chip timers. I could not, however, assume that the end users of my code would be able to spare a timer for the software I2C port. I had to forego the elegance (and to some extent accuracy) of the on-chip timers for the sledgehammer approach of software timing loops. Luckily, the I2C protocol is extremely forgiving with regard to timing accuracy. The decision to use assembly instead of a high-level language stemmed directly from the need to control program-execution time. I had neither the time nor the inclination to handtune high-level code. Having made the decision to use assembly language, I faced my next problem: Could I make the code portable? Intel offers a plethora of CPU and embedded-controller architectures. Would it be possible to make the code somewhat portable between disparate assembly languages? I found my answer in the use of marcos. Dr. Dobb's Journal, June 1992 All the basic building blocks of the I<sup>2</sup>C protocol (watching, waiting, and doing) can be compartmentalized into distinct macros. The algorithms that make up the I<sup>2</sup>C driver are written with these macros as the framework. You don't need to understand the intricacies of the I<sup>2</sup>C protocol to port these routines—you can be used to know how to make your CPU watch, wait, and do. For example, a 4.7\_uS delay is a common event during a transfer. The macro \( \text{Wait}\_4 \) 7\_uS implements just such a delay by using the 8086 LOOP instruction with a couple of NOPs for tuning; see Example 1(a). Total execution time is readily calculated from instruction timing tables. The same macro is ported to the i960 architecture in Example 1(b). Although I am a neophyte when it Figure 1: Flowchart of process for transmission of a single bit. comes to i960 programming, I had no problems porting the core macros. #### **Hardware Dependencies** A few words about the target hardware are in order before I discuss the code. Any implementation of the 1<sup>2</sup>C protocol requires two open-drain (or open-collector), bidirectional port pins for the Serial Clock (SCL) and Serial Data (SDA) lines. The code in this article was designed for the 80C186EB embedded processor, which has two open-drain ports on-chip. The two pins, P2.6 (SCL) and P2.7 (SDA), are part of a larger 8-bit port. Processors without open-drain I/O ports can easily implement I<sup>2</sup>C with the addition of an external open-collector larch Two special-function registers, P2PIN and P2LTCH, are used to read and write the state of the port pins. The 80C186EB allows the special-function registers to be located anywhere in either memory or I/O space. For this implementation, I chose to leave the registers in I/O space, even though this limited my choice of instructions. The 80186 architecture does not provide for readmodify-write instructions in I/O space (an AND to I/O, for example); it can only load and store (IN and OUT). So why did I limit myself? Again, I had to assume the lowest common denominator for our customers when designing my code. #### **Building the Framework** Early on in development, I decided to partition my code macros according to physical processes involved in the I<sup>2</sup>C protocol. Code not directly involved in mimicking the actions of a hardware I2C port was not written as macros. For example, the code necessary to access the stack frame is not written as a macro, whereas the code needed to toggle the clock line is. This was done to isolate architecture-dependent code sequences from the more generic I2C functions. Macros were also not used for "gray areas" such as the shifting of serial data, which is both architecture dependent and physical in nature. The I2C functions that passed the litmus test fell into the three aforementioned categories of watching, waiting, and doing. The "waiting" macros provide a fixedminimum time delay. They are implemented using a simple LOOP \$ delay. The LOOP instruction decrements the CX register, then branches to the target (in this case itself) if the result is nonzero. The delay is (n-1)\*15+5 clocks. where n is the starting value in the CX register. All the delays were calculated assuming a 16-MHz clock rate (62.5) nanoseconds per clock). The code still works at lower CPU speeds because the I2C protocol only specifies minimum timings. In fact, the delay macros are only "accurate enough," providing timings as close as I could get to the specified minimum without undue tuning. The "watching" macros are "spin-on-bit" polling loops. These pieces of code wait for a transition on the appropriate I<sup>2</sup>C line to occur before allowing execution to continue. There are two polling macros for each of the two I<sup>2</sup>C signal lines; one for high-to-low transitions and one for low-to-high transitions. The ``` %*DEFINE(Wait_4_7_uS)( mov ; 4 clocks loop 4*15+5 = 65 clocks ; 3 clocks nop 3 clocks total = 75 clocks 75 * 62.5ns = 4.69uS (close enough) (b) define(Wait_4_7_uS,' 0x17, r4 # instruction may be issued in parallel # so assume no clocks. cmpdeco 0, r4 # compare and decrement counter in r4 if !=0 branch back (predict taken # The cmpdeco and bne.t together take 3 # clocks in parallel minimum. 0x17 (25 \text{ decimal}) * 3 = 75 \text{ clocks} # at 16MHz this is 4.69uS ``` **Example 1:** (a) 80C186 implementation of 4.7\_uS wait macro; (b) 80960CA implementation of 4.7\_uS wait macro. 2 # Programming the I<sup>2</sup>C interface 120 polling of the SCL line that gives rise to an important feature of I<sup>2</sup>C: automatic, bit-by-bit baud-rate adjustment. Any device on the I<sup>2</sup>C bus may hold the clock line low in order to stall the bus for more time (a serial wait state). The other devices on the bus are then forced to poll the SCL line until the slow device releases control of the clock. The *%Get\_SDA\_Bit* macro also falls under the category of "watching." Its function is simply to return the state of the SDA line without waiting for a transition. *%Get\_SDA\_Bit* is used primarily to pull the serial data off the bus when the clock is valid. The "doing" macros control the state of the clock and data lines. As with the polling macros, there are four typesone for each transition of the SCL or SDA lines. The "doing" macros are named to reflect the physical operations they perform. For example, %Drive\_ SCL\_Low always drives the SCL line to a low state. %Release\_SCL\_High, on the other hand, relinquishes control of the SCL line, which may then be pulled high or driven low by another device on the bus. A read-modify-write operation is used for the bit manipulation so that the other 6 bits of Port 2 are not affected by the I2C operations. #### Getting on the Bus Three procedures were created using the macro framework. I'll describe only the master transmit (Listing One, page **Figure 2:** Flowchart for I<sup>2</sup>C transmit procedure. 106) and master receive functions (Listing Two, page 108), as they represent the needs of most I<sup>2</sup>C users. The slave procedure is long and intricate and will not be described here. An I<sup>2</sup>C master transmission proceeds as follows: - 1. The master polls the bus to see if it is in use. - The master generates a start condition on the bus. - 3. The master broadcasts the slave address and expects an acknowledge (ACK) from the addressed slave. - 4. The master transmits 0 or more bytes of data, expecting an ACK following each byte. - The master generates a stop condition and releases the bus. The stack frame for the master transmit procedure, I2CXA.886, includes a far pointer to the message for transmission, the byte count for the message, and the slave address. Far pointers and far procedure calls are used in all the procedures. No attempt was made to conform to a specific high-level language calling convention, although such a conversion would be trivial. The procedures save only the state of the modified segment registers. The master transmit procedure performs error checking on the passed parameters before attempting to send the message. The maximum message length is set at 64 Kbytes by the segmentation of the 80186 memory space. This restriction could be removed by including code to handle segment boundaries. The transmit procedure also checks the direction bit in the slave address to ensure that a reception was not erroneously indicated. Errors are reported back to the calling procedure through the AX register. (The exact code is in Listing One.) The first step in sending a message is getting on the 1<sup>2</sup>C bus. The macro 6*KCheck\_For\_Bus\_Free* simply polls the bus to determine if any transactions are in progress. If so, the transmit procedure aborts with the appropriate error code. If the bus is free, a start condition is generated. The start condition is defined as a high-to-low transition of SDA with SCL high followed by a 4.7\_uS pause. These waveforms are easily generated with the *\*%Drive\_SDA\_Low* and *\*%Wait 4.7 uS* macros. All communication on the I<sup>2</sup>C bus between the stop and start conditions, including addressing and data, takes place as an 8-bit data value followed by an acknowledge bit. This lead to the natural nested loop structure for the body of the procedure; see Figure 2. The inner loop is responsible for transmitting the 8 bits of each data byte. Each transmitted bit generates the appropriate data (SDA) and clock (SCL) waveforms while checking for both serial wait states and potential bus collisions. A bus collision occurs when two masters attempt to gain control of the Three distinct tasks are involved in implementing the I<sup>2</sup>C protocol: watching the bus, waiting for a specific amount of time, and driving the bus bus simultaneously. The 1<sup>2</sup>C protocol handles collisions with the simple rule: "He who transmits the first 0 on the SDA line wins the bus." To ensure that we (the master transmit procedure) own the bus, the SDA line is checked whenever transmitting a 1. If a 0 is present, then a collision has occurred (because another master is pulling the line low), and the transfer must be aborted. Control is turned over to the outer loop after the 8 bits of data (or address) have been transmitted. The outer loop immediately checks for an acknowledge from the addressed slave. The transfer is aborted if an acknowledge is not received. At the end of the ACK bit the message length counter is decremented. Control is returned to the inner loop if more data remains, otherwise a stop condition is generated and the master transmit procedure terminates. Registers are used for intermediate result storage throughout the body of the procedure. For example, the AH register is used to hold the current value (either address or data) being shifted onto the SDA line. This eliminates the need for local data storage within the procedure. #### On the Receiving End The steps involved in an I<sup>2</sup>C master receive transaction are almost identical to those in transmission: - 1. The master polls the bus to see if it is in use. - 2. The master generates a start condi- Dr. Dobb's Journal, June 1992 tion on the bus. - The master broadcasts the slave address and expects an ACK from the addressed slave. - 4. The master receives 0 or more bytes of data and sends an ACK to the slave after each byte. The master signals the last byte by not sending an ACK. - The master generates a stop condition and releases the bus. A far pointer to the receive buffer is passed on the stack to the master receive procedure. The remainder of the parameters—slave address and message count—are identical between the two procedures. The received message length is fixed at 64 Kbytes, again because of segmentation. The error-checking, bus-availability sensing, and start-condition generation sections of the receive procedure are lifted verbatim from the transmit code. The structure of the receive procedure differs slightly once the start con- Figure 3: Flowchart for I2C receive procedure. dition has been generated; see Figure 3. The slave address is transmitted using one iteration of the transmit procedure's outer loop. Control is passed to the receive loop once the slave acknowledges its address. The receive loop structure is patterned after that of the transmit procedure. The inner loop controls the clocking of the SCL line and the shifting of the serial data off the SDA line into the CPU. Eight iterations of the inner loop are performed to receive each byte. The outer loop stores the received byte in the buffer, decrements the byte count, then sends an ACK to the slave. The last data byte is signalled by not sending an ACK. #### Using the Procedures Listing Three (page 110) shows a short program that uses both the master transmit and master receive procedures. The call to procedure I2C\_XMIT displays the word "bUS-" on a four-character, seven-segment display controlled by the SAA1064 I<sup>2</sup>C compatible display driver. The time of day is read from the PCF8583 real-time clock by the call to procedure I2C\_RECV. Please note that interrupts must be disabled during the execution of both procedures. An interruption at an inopportune time (when the master is not in control of the clock) could cause the bus to hang. If you need to service interrupts periodically, then enable them only when the clock is driven low. These procedures have been tested on a wide array of 1<sup>2</sup>C devices ranging from serial EEPROMs to voice synthesizers. No compatibility problems have been seen to date. #### **Enhancing the Code** I've kicked around many ideas for enhancing the I<sup>2</sup>C procedures. You could, All the basic building blocks of the I<sup>2</sup>C protocol (watching, waiting, and doing) can be compartmentalized into distinct macros for example, replace the timing loops with timed interrupts. That way, the CPU could perform useful work during the pauses. Along the same lines, the pauses could be scheduled using a real-time kernel, again improving CPU throughput. Finally, you could add a high-level language calling structure. The use of timed interrupts adds an order of magnitude to the complexity of the code, but would be worth it for high-performance, real-time systems. #### Conclusion I<sup>2</sup>C is not the only game in town when in comes to serial protocols. Hopefully, some of the techniques presented here will carry over into the development of other "simulated" serial protocols, such as those targeted at the home-automation market. Who knows, maybe someday a snippet of my code may find its way into a truly intelligent dishwasher. I'll be waiting.... #### References I<sup>2</sup>C Bus Specification, Philips Corporation (undated). DDJ # Reprinted with permission of Dr. Dobb's Journal, 1992 Entire contents copyright © 1992 by M&T Publishing, Inc. Inless otherwise noted on specific articles All rights reserved. June 1992 272 # **Philips Semiconductors** # **Section 4 ACCESS.bus Technical Overview** Application Notes and Development Tools for 80C51 Microcontrollers #### CONTENTS | ACCESS.DUS TECHNICAL OVELVIEW | 275 | |---------------------------------------|-----| | Introduction | 275 | | What is ACCESS.bus? | 275 | | ACCESS.bus natuwate | 275 | | ACCESS.bus Protocols | 276 | | How ACCESS.bus Works | 277 | | Electrical | 277 | | | 277 | | Synchronization | 279 | | Byte Framing and Acknowledgement | 279 | | Addressing | 279 | | Arbitration | 279 | | Message Format | 279 | | Control/Status Messages | 279 | | Configuration | 280 | | Colliquiation | 281 | | Device identifiers | 281 | | Device Capabilities information | 282 | | Application Device Types | 282 | | Reyboard Devices | 282 | | Locator Devices | 282 | | | 282 | | Infilling holes | 282 | | Halisaction filling hules | | | | 282 | | Soliware Architecture and Development | 282 | | Device Filliwate Development | 283 | | HOSE SOftware Architecture | 283 | | Development Support | 283 | | ACCESS, bus industry Group | 283 | | Philips Semiconductors Support | 283 | | | 284 | | ACCESS.bus development kit | 204 | | ACCESS.bus PC/AT controller board | 286 | | | | # ACCESS.bus™ technical overview #### INTRODUCTION ACCESS.bus™ (a BUS for connecting ACCESSory devices to a host system) is a peripheral interconnect system defined and developed by Digital Equipment Corporation and offered to the computer industry as an open standard. This overview aims to introduce the prospective developer of ACCESS.bus systems or peripherals to the essential technical features of this interconnect. It is meant to be a general technical overview of the ACCESS.bus architecture. Under no circumstances should it be used as the basis for designing any device or system. Developers wishing to design a host system or peripheral device that implements ACCESS.bus should refer to the ACCESS.bus Hardware and Protocol Specifications Version 2.0, July 1992, available from the ACCESS.bus Industry Group, Digital's TRI/ADD Program, or Philips. Addresses and other information on support may be found in Section 6. #### What is ACCESS.bus? ACCESS.bus is a system for connecting a number of relatively low-speed I/O devices to a host computer, typically a desktop system, such as a workstation, personal computer, or terminal. Devices include both interactive peripherals – keyboards, locators, hand-held scanners, bar code readers, and magnetic card readers – and non-interactive peripherals – printers, and in realtime control applications, signal transducers. Further, the ACCESS.bus protocol is general enough to accommodate a wide range of unusual peripheral types such as data gloves (see Figure 1). ACCESS.bus has a bus topology architecture. That is, a single ACCESS.bus on a host can accommodate up to 125 peripheral devices. The total length of the cable connecting the devices on a common ACCESS.bus may be up to eight meters. The limiting factors are capacitance, which may not exceed 800pF, and the maximum voltage drop, which must allow maintenance of +5V ±10%. Using an I<sup>2</sup>C bus extender that maximum distance may be lengthened. ACCESS.bus supports a maximum aggregate data throughput of approximately 80 Kbits/sec. Digital has made the ACCESS.bus technology an open specification, enabling any vendor to implement it on host systems or in peripheral devices without fee or royalty. ACCESS.BUS offers a number of advantages both to end users and to the developers of systems and peripheral devices. A host computer needs only one hardware port to connect to a number of devices. The commonality in communication methods for a number of device types leads to economies in software and hardware development. As an open industry standard, ACCESS.bus will stimulate development of diverse peripheral devices, each usable with a number of different types of host systems. ACCESS.bus incorporates more sophisticated technology and offers higher performance than any other bus-topology interconnect for desktop peripherals. Moreover, it is the first system of this kind to be offered as an open nonproprietary standard. #### **ACCESS.bus Hardware** At the hardware level, ACCESS.bus is based on the well-established Inter-Integrated Circuit (I<sup>2</sup>C) serial bus developed and patented by Philips. The serial bus architecture, in which a single data line carries one bit of information at a time, entails lower costs for cabling, connectors and controller circuitry than parallel bus architectures. Standard low-cost I<sup>2</sup>C components, available from Philips, handle the logical complications of the bit-level handshaking. More details on these components are given in section 5. Figure 1. ACCESS.bus connects keyboards, locators, and text-type devices to a system. ACCESS.bus is a trademark of ACCESS.bus Industry Group #### ACCESS.bus™ technical overview Figure 2. A shielded connector with four pins for connecting the ACCESS.bus cable to a system Figure 3. Female Connector Pin Identification (Not To Scale) The physical medium for ACCESS.bus is a shielded cable containing four wires: serial data (SDA), serial clock (SCL), power (+5V), and ground (GND). It uses standard low-cost shielded modular connectors available from AMP and Molex (Figure 2 and 3). Shielding of the cables and connectors facilitates making ACCESS.bus-based systems conform to FCC radiation and ESD requirements. A typical ACCESS.bus device will have two connectors so that devices may be chained on the single bus; hand-held devices may have a captive cable joined to the bus trunk with a "T" connector. The serial data (SDA) and serial clock (SCL) lines work together to define the information carried on the bus. That aspect of the technology is described in Section 2.3. The host computer drives the +5V power line with a minimum of 50mA to supply the peripheral devices. Devices may be supplied with power from an external source. The I<sup>2</sup>C technology can support clock rates up to 100kHz. The maximum ACCESS.bus data transfer rate of approximately 80 Kbits/sec is derived from the top clock rate by subtracting the overhead imposed by the ACCESS.bus communication protocols for handshaking, addressing, and error control. #### **ACCESS.bus Protocols** The ACCESS.bus communication protocol is composed of three levels: I<sup>2</sup>C Protocol, Base Protocol, and Application Protocol. At the lowest level, nearest the hardware, the basic discipline of the ACCESS.bus is defined as a subset of the Philips Inter-Integrated Circuit (I<sup>2</sup>C) bus protocol. The simple and efficient I<sup>2</sup>C Protocol defines a symmetric multi-master bus on which arbitration among contending masters is effected without losing data. I2C provides for cooperative synchronization of the serial clock for exchange of data between bus partners with different maximum clock rates. The I<sup>2</sup>C Protocol defines a bus transaction scheme with addressing, framing of bits into bytes, and byte-acknowledgement by the receiver. More detail on the I2C Protocol level is given in Section 2. The next ACCESS.bus protocol level is the Base Protocol. This level, common to all types of ACCESS.bus devices, establishes the nature of ACCESS.bus as an asymmetrical interconnect between a host computer and a number of peripheral devices. The host plays a special role as a manager of the ACCESS.bus. Data Comr.unication is always between host and peripheral device and never between two peripherals. While the I<sup>2</sup>C Protocol provides for mastership by either the sender or the receiver of a bus transaction, in the ACCESS.bus protocol masters are exclusively senders and slaves are exclusively receivers. Of course, the host and all the devices are both master/senders and slave/receivers at different times. The ACCESS.bus Base Protocol defines the format of an ACCESS.bus message envelope, which is an I<sup>2</sup>C bus transaction with additional semantics, including checksum reliability control. Further, the Base Protocol defines a set of seven control and status message types which are used in the configuration process. The eight required interface massages that ACCESS.bus protocol defines are listed below. Parameters defined within the body of the message are listed in parenthesis. Computer-to-device Messages: Reset() Identification Request() Assign Address(ID strng, new addr) Capabilities Request(offset) Device-to-computer Messages: Attention(status) Identification Reply(ID string) Capabilities Reply(offset, data frag) Interface Error() #### ACCESS.bus™ technical overview Two of the unique features of this configuration process are auto-addressing and hot plugging. Auto-addressing refers to the way that devices are assigned unique bus addresses in the configuration process, without the need for setting jumpers or switches on the devices. Hot plugging refers to the ability for attaching or detaching devices while the system is running, without the need for rebooting the host. The means by which the ACCESS bus protocol provides these feature is discussed in Section 2. The highest level of the ACCESS.bus protocol, the Application Protocol, defines message semantics that are specific to particular functional types of devices. Different device types require different Application Protocols. Application Protocols have been defined so far for three device classes: keyboards, locators, and text devices. Each of these predefined classes is designed to be broad. The keyboard device protocol defines standard messages for reporting keystrokes and controlling keyboard peripherals. The protocol attempts to define the simplest set of functions from which common industry standard keyboard interfaces can be built. The locator device protocol defines a set or standard messages for reporting locator movement and key switch activation for mice, tablets, and other positioning devices. The protocol is designed to accommodate a range of basic locator devices such as a mouse or tablet. More complex devices can be modeled as a combination of basic devices or can provide their own device driver. The text device protocol is intended to provide a simple way to transmit character or binary data to and from stream oriented devices such as a bar code reader, or modem. The sequential character stream model also serves as a common denominator for connecting RS-232 interface devices. A major advantage in designing devices that conform to these general device-type semantics is that they may share device-specific software, both in the device-resident firmware and in the driver software needed in the host operating system to allow application programs to access the devices. It is anticipated that further device-specific Application Protocols will be defined in the future, under the aegis of the ACCESS.bus Industry Group. Further, any device vendor may implement a special device protocol within the general message envelope defined by the Base Protocol. Participation in all three of the protocol levels requires intelligence at the device level. The lower levels of this firmware are likely to be common to many devices. Higher levels of the firmware are expected to be more specific to the device and the application (Figure 4). #### **HOW ACCESS.bus WORKS** #### **Electrical** The host and devices are connected to both the serial data (SDA) and serial clock (SCL) lines in an "wired-AND" logic configuration. The wired-AND may be implemented by connecting the data and clock output stages of each bus partner to the SDA and SCL lines respectively through open-collector or open-drain transistors. The standard I<sup>2</sup>C components include such output stages on-chip. The significance of the wired-AND logic is that any attached bus partner may force either of these lines to low (the ground level). When there is no output from any bus partner, the lines are held high by pull-up current sources in the host. Every bus partner can sense the level on both of these lines (Figure 5). #### **Bus Transactions** During a bus transaction, there is one clock pulse on SCL for each bit transferred on SDA. The SDA information is valid when SCL is high. During a transaction, the SDA must be stable between the rising and falling edges of the SCL pulse; SDA may change state only when SCL is low (Figure 6). SDA transitions when the SCL is high are signals that delimit the bus transaction. When the ACCESS.bus is free, both SCL and SDA are high. A high-to-low SDA transition when SCL is high is a start condition; it signals the beginning of a bus transaction. A bus partner asserts mastership by pulling SDA low when the bus is free. A low-to-high SDA transition when SCL is high is a stop condition; it signals the end of a bus transaction. A master generates a stop condition when it relinquishes mastership (Figure 7). Figure 4. ACCESS.bus protocol hierarchy # ACCESS.bus™ technical overview Figure 5. Connection of Devices to the I<sup>2</sup>C Bus Figure 6. Bit Transfer on the I<sup>2</sup>C Bus Figure 7. Start and Stop Conditions # ACCESS.bus™ technical overview #### **Synchronization** When a bus partner wishes to assert mastership of a free bus, it generates a start condition by pulling the SDA low. When SDA is low the new master begins the clock cycle, pulling the SCL low. All bus partners must be able to sense these events, and they respond by pulling all their SCL outputs low and beginning to count off their low periods. When each bus partner has reached the end of its low period, it lets its SCL output go high. Thus the SCL line will remain low for the duration of the longest low clock period among the bus partners. When all the bus masters have reached the end of their low periods and let their SCL outputs go high, then the SCL goes high. All bus partners must be able to sense this event, and they begin counting their high period. The first bus master to reach the end of its high period pulls the SCL low again. In this way, all the bus partners simultaneously communicating on the bus are synchronized by a clock pulse whose low is as long as the longest of the low periods and whose high is as long as the shortest of the high periods. This synchronization persists until the master relinquishes the bus by generating a stop condition. The cooperative synchronization is a mechanism by which devices with slower clocks can regulate the operating rate of the bus. However, this mechanism, called "clock stretching", is not the normal means of data stream flow control. The ACCESS.bus protocol provides another mechanism for this purpose. (See Section 3.3.) # Byte Framing and Acknowledgement During this synchronized exchange the master/transmitter puts data on the SDA, one bit for each clock pulse. Eight successive bits comprise a byte, the most significant bit going first. The ACCESS bus is a Big Endian System. As the new master puts the first byte on the bus, all the other bus partners participate in the synchronization. The first byte of the transaction contains the address of the intended slave/receiver of the transaction. Each non-master can check the address bits as they appear and cease participating in the synchronization as soon as the address bit on SDA fails to match the corresponding bit of its own address. The address check may also be done at the end of the address transmission. At the end of the first byte, the master/transmitter lets its data output go high for the next clock pulse and the slave/receiver whose address matches the transmitted address, is obliged to acknowledge receipt of the byte by pulling the SDA low for this pulse. This 1-bit Ack continues after each byte of the bus transaction; the master lets its SDA output go high and the receiver must pull the SCL low. Failure of the receiver to acknowledge a byte is an exception condition, which requires the master to terminate the transaction. #### Addressing The slave/receiver of the bus transaction is determined by the address contained in the first byte. I<sup>2</sup>C uses the seven high-order bits of the first byte for addressing, and bit 0 to indicate whether the master is transmitting or receiving data. In ACCESS.bus, the master is always the transmitter, so bit 0 of the first byte of a transaction is always 0. Of the 128 7-bit addresses ACCESS.bus uses 15 addresses for general microcontrollers. The host computer address is always 50h. In the configuration process to be described below, each peripheral device is assigned a unique address from the set of even numbers. 6Eh is used as a default address for devices before they have been assigned a unique address. A total of 125 addresses are available for devices on the bus. #### Arbitration What happens when two devices simultaneously assert mastership? While putting data on the SDA, each transmitting master is, of course, independently sensing the state of SDA. Whenever a contending master detects that the state of the SDA is different from the data value it is putting out during a clock high, the contending master backs off, and waits for the stop condition before trying again, Thus, two contending masters will both put data on the bus as long as they are putting out the same data. The first bit where they differ will cause the contender that put out a 1 to back off. Thus, under normal expected operation contending masters trying to send to different bus addresses will resolve the contention by the end of the first byte of the bus transaction. In the ACCESS.bus Base Protocol, the second byte of a transaction is the address of the transmitting master. Thus, as long as bus addresses are unique, the mastership of the bus will be resolved by the end of the second byte of the transaction. However, if two devices have the same address and are trying to send identical messages to a common address, then they will both send the entire message in unison. this situation can happen only during the configuration process before devices have all been assigned unique addresses; it is discussed further in Section 2.9 below. Note that this arbitration mechanism never causes lost data or wasted transmissions. since the addresses of the receiver and transmitter are necessary overhead, in any case, for any sensible bus protocol. Note that bus priorities during arbitration are fixed by the device addresses, first by the address of the receiver, and then, for messages addressed to a common receiver, by the address of the transmitter. Lower addresses have priority over higher addresses. Lockouts of devices with high addresses are prevented by a rule of the Base Protocol that requires partners to wait a minimum time after relinquishing mastership before asserting it again. #### **Message Format** An ACCESS.bus message comprises one I<sup>2</sup>C bus transaction. It consists of a string of bytes sent by a master/transmitter, each byte acknowledged by a one bit SCL-low Ack from the slave/receiver. The entire transaction is delimited by start and stop conditions generated by the master. The first byte in the message is the receiver's unique address, as described above in Section 2.5. The second byte contains the transmitter's unique address. The third byte of an ACCESS.bus message comprises two fields. Bits 2-7 provide a byte count for the body of the message. Thus, a message body can have 0 to 127 bytes. The message body is followed by a checksum byte, for error control. The checksum is the bitwise XOR of all the preceding bytes of the message. The high order bit of the third byte is a Protocol Flag (P) to distinguish between data stream messages (P=0) and control/status messages (P=1). The data stream messages carry the application information being exchanged between the device and the host. The control/status messages are used to manage the ACCESS.bus protocol (Figure 8). #### **Control/Status Messages** The ACCESS.bus Base Protocol defines a number of control/status messages that pertain to the Interface Parts of devices. These control/status messages are used for the configuration process, in which devices are assigned unique bus addresses and connected with the appropriate drivers in the host. The configuration process is described in Section 2.9 to 2.11. In a control/status message, the message type is indicated by an operation code contained in the first byte of the message body. The various Interface Part control/status messages are shown in Table 1. Version 2.0 #### ACCESS.bus™ technical overview Figure 8. ACCESS.bus Big Endian bit ordering # Table 1. Interface Part Control/Status Messages #### Computer-to-Device Messages Purpose #### Rasat/ Force device to power-up state and default I<sup>2</sup>C address. #### Identification Request() Ask device for its "identification string." # Assign Address(ID strng, new addr) Ask device for its "identification string" to change its address to "new address." #### Capabilities Request(offset) Ask device to send the fragment of its capabilities information that starts at "offset." #### Attention(status) Inform computer that a device has finished its power-up/reset test and needs to be configured; "status" shall be the test result. #### Identification Reply(ID string) Reply to Identification Request with device's unique "identification string." # Capabilities Reply(offset, data frag) Reply to Capabilities Request with "data fragment," a fragment of the device's capabilities string; the computer uses "offset" to reassemble fragments. #### Interface Error() Invalid checksum or premature end of message detected. In addition, the Application Protocols define further control/status messages that are specific to particular device types. Some of these are discussed in Section 3 on the predefined device types. #### AppHardSiga Provision for a subdevice to generate an interrupt of the host system #### AppTest A message from the host to a peripheral device commanding it to test the Application Part subdevice #### AppTestReply A message by which a device replies to an AppTest command. #### Configuration The ACCESS bus features auto-addressing and hot-plugging. These features are supported by the ACCESS bus configuration process, which uses the seven types of control/status messages. Configuration consists of assigning unique bus addresses to the attached devices and connecting them with the appropriate drivers to provide host-resident application programs with access to the devices. Configuration occurs when the device is powered-up or when it receives a Reset message. When the system is powered up, so are devices attached to the ACCESS bus. Otherwise, devices are powered-up when they are hot-plugged into the bus. A device 280 may have a power source other than the +5V power line of the ACCESS.bus, but is must also be able to sense this line voltage and enter the power-up state when attached to the ACCESS.bus power source. When the system completes its boot up, the host sends a Reset message to all legal device addresses to put all devices in the power-up state. Usually, when a device is powered up, it performs its specific self-testing. At the conclusion of self-test the device must assume the default address 6Eh and send an Attention message to announce its presence to the host. This message contains a single status byte to inform the host of the results of the power-up self-testing; zero indicates normal results and non-zero values indicate exception conditions that are specific to the device type. On receiving an Attention message, the host sends an IDRequest message to the default address. Each device at this address replies with an IDReply message containing a unique 28-byte ID string described in the next section. The host is then able to assign unique ACCESS.bus addresses to each of the devices at the default address, by sending AssignAddress messages to the default address. Each AssignAddress message contains in its body the assigned address and the unique ID string of the corresponding device. # ACCESS.bus™ technical overview #### **Device Identifiers** During configuration, before address assignment, each device can be identified by a 28-byte unique ID string, which may be partly or entirely encoded in the device ROM. The first 24 bytes of the ID string are understood as ASCII-encoded information characterizing the device type: • protocol revision 1 byte ("A") • module revision 7 bytes (e.g., "V1.0") • vendor name 8 bytes (e.g., "DEC") • module name 8 bytes (e.g., "LK501") device number 32-bit signed integer The first 24 bytes characterize the device's firmware and are encoded in the device ROM. The remaining 4 bytes of the device ID string are understood as a 32-bit two's complement integer that uniquely identifies the device among devices of the same type. This integer may be provided as a unique serial number contained in the device ROM. Or, in the absence of such a serial number, interactive devices may use a random or arbitrarily determined number for this part of the ID string. As an aid to the host software, the Base Protocol specifies that, in the IDReply message, unique serial numbers be sent as positive integers and randomly generated numbers be sent as negative integers, in the two's complement sense. In the random number case, it is possible that different devices of the same type may come up with the same 32-bit discriminator. In this case, the different devices will be assigned the same bus address, an undesirable situation. The ACCESS bus specification suggests a guideline to help avoid identical random identifiers: use the number of cycles of the device's own clock between power up and the time the IDRequest message is received. The natural dispersion of the frequencies of these oscillators is likely to provide unique numbers. The Base Protocol includes a provision to ensure against the unlikely circumstance that different interactive devices of the same type and without unique serial numbers will generate the same random number. Namely, each such device must send a Reset message to its own assigned address. This self-addressed Reset is sent only once between power-ups or external Resets, just before the device sends the first message instigated by a user action. Of course, the transmitting device will ignore the self-addressed Reset, but other devices possibly at the same address will be reset and will go through configuration again. The Base Protocol specifies that a device using a random number in its ID string shall change that random number after receiving a Reset message. In this way, all interactive devices are guaranteed assignment of unique addresses before sending their first data-carrying messages. If several non-interactive devices of the same type are to be attached to a single ACCESS.bus, then they must have hardwired unique serial numbers. During normal operation, the host periodically checks the configuration by sending IDRequest messages to inactive devices. The host also sends IDRequest messages to all assigned addresses whenever it receives an Attention message from a device seeking configuration. The purpose of these IDRequest messages is to verify the current state of the ACCESS.bus – what devices are still connected and which devices are no longer present. #### **Device Capabilities Information** In order that a device be accessible to application programs running on the host, it must be connected to an appropriate software driver. Establishing this association is the last phase of configuration. The appropriate driver will depend on the device type. There may be further parameters that characterize the device and which affect the choice of driver, or which at least must be furnished as arguments to the selected driver. Moreover, the application program may also need to be informed of these device parameters. The device Capabilities Information feature of the ACCESS.bus protocol allows a measure of device independence in the selection of drivers and provides for informing the host software of the device characteristics. Device Capabilities Information is an explicit statement of a device's functional characteristics that are only implicit in the device type designation contained in the ID string, or that may even vary among individual devices of a given type. For example, the Capabilities Information about a keyboard might include the national alphabet used, or the Capabilities Information about a locator might include its resolution or units. The Capabilities Information for each device is contained in a single human-readable ASCII-encoded text string stored on the device ROM. The ACCESS.bus Base Protocol defines a simple and compact grammar for building the capabilities string. The semantics of the Capabilities Information is carried by keywords. The Base Protocol defines some keywords that can apply to all sorts of devices. Then each Application Protocol will define further keywords that are meaningful only for certain types of devices. To date, the ACCESS.bus Application Protocols define semantics for the Capabilities Information for generic keyboards, locators, and general text devices. The grammar allows for easy extension of the Capabilities Information specification. An example of a simple mouse Capabilities string might be as follows: ``` prot(locator) type(mouse) model(VSXXX) buttons(1(L)2(R)3(M)) dim(2) rel res(200 inch) range(-127 127) d0(dname(X)) d1(dname(Y)) ) ``` This would specify that the device uses the standard locator protocol; that it is a mouse, that it is model VSXXX; that it has three buttons designated left, middle and right corresponding with the respective bits in the keyswitch word; that it has two degrees of freedom, designated "X" and "Y", using inches as units with 200 counts per inch; that it reports relative values (displacement since last report) in the range -127 to 127 counts, and that its coordinate values correspond to X and Y. After assigning a unique address to a device, the host sends it a CapRequest message to command it to send its Capabilities Information in a CapReply message. Of course, the device Capabilities string may well exceed the capacity of the message body of each CapRequest specifies where in the Capabilities Information string the fragment should start. The 'offset' value is repeated in the CapReply message, to be used as a check by the host in reassembling the Capabilities string. The offset is restricted to three values: send first (0), send again, and send next (offset from most recent string plus the number of bytes in the fragment. The prot(), type(), and model() keywords must appear in that order and occur first in the Capabilities string. They must be within the first 128 bytes. # ACCESS.bus™ technical overview #### **APPLICATION DEVICE TYPES** The initial ACCESS.bus specification defines Application Protocols for three kinds of devices: keyboards, locators, and text devices. An important advantage of developing devices that conform to these defined protocols is the availability of pre-existing software to implement them, in particular, the drivers in the operating software of the host system through which application programs gain access to the devices. #### **Keyboard Devices** A generic keyboard consists of an array of key stations assigned numbers between 8 and 255. When any key station transitions between open and closed, the entire list of key stations currently closed or depressed is transmitted to the host. In addition to reporting key stations, the generic keyboard device can support simple feedback mechanisms such as keyclicks, bells, and light-emitting diodes. These mechanisms are controlled explicitly from the host so that minimal keyboard state modeling is required. The keyboard mapping table can also be stored in the keyboard itself as part of the capabilities string. Each key is assigned a unique 8-bit number (8-255). The first 8 codes are reserved for other keyboard functions. On each key transition, up or down, the keyboard will report the complete state of the key array as a list of zero to ten key stations that are currently down. Example: user enters the modified keystroke Alt-Shift-A | Transition | Report | |------------|-------------------------| | Alt down | Alt | | Shift down | Alt Shift | | 'A' down | Alt Shift A | | 'A' up | Alt Shift | | Shift up | Alt | | Alt up | <empty list=""></empty> | This reporting scheme is functionally complete in that the host can detect every key transition and it provides the full state of the keyboard on each report. No special resynchronization reports are needed. More detailed information can be found in the ACCESS.bus Keyboard Device Protocol Specification. #### **Locator Devices** The ACCESS.bus Locator Device Specification provides for a device that has up to 15 degrees of freedom (with 16-bit precision) and up to 16 binary keys or buttons. Thus, in addition to such conventional pointer/locator devices as mouse, tablet, trackball. The ACCESS.bus locator protocol is suitable for valuator sets, such as dial boxes, and function key boxes with up to 16 function keys. The locator capabilities information provides for specifying the number of switches and their designations (for example, "left", "right", "middle", etc.), whether the locator values are relative (like a mouse) or absolute (like a tablet or dial box), the resolution (counts per unit, and units), the dynamic range, and the names of the locator axes (for example, "x", "y", etc.). The first 2-byte word of the event report message body contains a mask giving the state of the switches; the remaining words contain the value of each of the locator axes, either the absolute values or the change since the previous report in the case of relative devices. The locator report message is sent either on a regular sampling interval or on receipt of an AppPoll message from the host. The locator-specific Application Protocol control/status messages are from the host to the device: #### AppPoll Requests the device to report its state #### **AppSamplingInterval** Sets the device sampling interval or instructs the device to report only when polled More detailed information can be found in the ACCESS.bus Locator Device Protocol Specification. #### **Text Devices** The text device protocol is intended to provide a simple way to transmit character or binary data to and from stream oriented devices such as a bar code reader, or character display. The sequential character stream model also serves as a common denominator for connecting RS-232 interfaced devices. A generic text device transmits a stream of 8-bit bytes from a character set. Simple control messages are defined to support flow control and to select communication parameters that might be used to interface with a modem. The capabilities string contains information that identifies the specific character set and communication parameters used. More detailed information can be found in the ACCESS.bus Text Device Protocol Specification. #### **TIMING RULES** To ensure good interactive response and to ensure that all devices will have access to the bus, the ACCESS.bus specifies rules on transaction timing. Further, specific timeouts are needed to avoid hanging up the interconnect when devices fail or are removed. #### **Transaction Timing Rules** The ACCESS.bus is designed primarily for interactive devices. A basic objective of the definition of the ACCESS.bus specification is that every interactive device should be able to update the host on its state at least once in every display video frame time. To help meed this criterion, the Base Protocol imposes some rules on the timing of a device's interaction with the bus. #### **Response Timeouts** In order that a dead or unplugged device will not hang up the system indefinitely, there must be time limits for responding to commands that require a response. The ACCESS bus protocol specifies that devices shall complete the Reset command within 250ms. Further, a device shall respond to any command requiring a response within 40ms, or, in the case of commands that can be answered by several devices, within 40ms after the last device to respond. # SOFTWARE ARCHITECTURE AND DEVELOPMENT An ACCESS.bus peripheral requires software at both ends of the bus transaction for managing all levels of the peripheral interaction: the I2C interface, the ACCESS.bus Base Protocol, and the ACCESS.bus Application Protocol. Further, the peripheral device requires software to support communication between the device microcontroller and the application-specific I/O transducer circuitry. Finally, the host system operating software must provide interfaces by which application programs can access both the ACCESS.bus devices and the ACCESS.bus itself. An important advantage of the ACCESS.bus approach is that the lower levels of the interaction are common to diverse device types, so they can be supported by the same or similar software modules. #### ACCESS.bus™ technical overview #### **Device Firmware Development** The microcontroller in the device provides the intelligence for managing the device's participation in all the levels of the ACCESS.bus protocol. Use of the components with hardware I2C interface functionality, described in "MICROCONTROLLERS", can simplify the development of the lowest level of this software. Moreover, because they concern only the bus communication methods that are common to all sorts of peripheral devices, the I2C interface and the ACCESS.bus Base Protocol may well be implemented by reusing software previously developed for some of these components. And devices conforming to the semantics of the predefined standard Application Protocols may also benefit from the availability of some off-the-shelf code at the top level. Of course, each device vendor will have to develop substantial firmware specific to his or her device. Philips and several third party vendors offer a range of tools to support firmware development for the standard components of the 80C51 family. These tools include cross assemblers and cross compilers for C and PL/M, in-circuit emulators with symbolic debugging and real-time trace support, and EPROM programming equipment. Generally, these software and hardware tools are for use with PC-compatibles as the development platforms. #### **Host Software Architecture** Vendors of host systems supporting ACCESS.bus will have to supply drivers and other kernel modules to provide access to the ACCESS.bus port, both for application program clients and for other system software, such as the interactive I/O handlers of the window system. #### **DEVELOPMENT SUPPORT** Both Digital and Philips Semiconductors offer technical support and assistance to developers of ACCESS.bus devices and host systems. #### **ACCESS.bus Industry Group** The ACCESS.bus Industry Group (ABIG) is an association of members interested in promoting ACCESS.bus as an industry standard for the desktop connectivity of computer peripherals. As an association, ABIG is intended to maintain the ACCESS.bus specification as a simple, easy-to-implement, stable technology in the spirit of its design and contribute to the technical longevity of the ACCESS.bus architecture. ABIG is an open industry group and anyone who has an interest in ACCESS.bus can be an ABIG member. An ABIG member is defined as a company including its divisions and subsidiaries, an organization, or a public or private institution. There are two basic types of membership; General and Voting. General membership is open to everyone and Voting Membership is restricted to only those members who are actively developing a device or platform that incorporates the ACCESS bus technology. ABIG is governed by an elected Steering committee of seven voting members. ABIG Founding Members are those voting members who joined to form ABIG. They have the same voting privileges. The ABIG Founding Members are: AMP, Inc. Ceibo, Ltd. Computer Access Technology Corp. Digital Equipment Corp. Discrete Time Systems Corp. Honeywell Keyboard Division Input Technologies, Inc. ITAC Systems, Inc. Kensington Microware Limited Lexmark International, Inc. Logitech, Inc. Micro Computer Control Corp. Molex Inc. Mouse Systems Corp. New Idea Electronic Co., Ltd. Nexus Applied Research, Inc. Penny & Giles Computer Products Ltd. Philips Semiconductors Robert Clemens Research & Development Summagraphics Corp. Sun International, Inc. Welch Allyn, Inc. For more details on ABIG, please contact ABIG directly at: ACCESS.bus Industry Group 370 Altair Way, suite 215 Sunnyvale, California 94086 Telephone: 408-991-3517 FAX: 408-991-3773 #### **Philips Semiconductors Support** An ACCESS.bus specification is available from Philips Semiconductors. This kit includes the complete specifications for the ACCESS.bus Base Protocol and pre-defined Application Protocols, as well as the Philips Data Handbook containing the detailed specification of the I<sup>2</sup>C bus, characteristics of the available integrated circuits which support it, application notes, and sample firmware code. The Data Handbooks also contain listing of development systems and third-party products supporting microcontroller firmware development, mentioned in the section entitled "Device Firmware Development". Beside the 80C51-family microcontrollers, Philips and other manufacturers offer over 100 different components with built-in I<sup>2</sup>C support: memories, display controllers, data converters, clock/calendars, voice synthesizers, video processors, and others. For technical questions on I<sup>2</sup>C call your local Philips Semiconductors sales office, or contact the Philips' Headquarters Application Group at [1]408-991-3518. Purchase of Philips' I<sup>2</sup>C components conveys a license under the Philips' I<sup>2</sup>C patent to use the components in the I<sup>2</sup>C-system provided the system conforms to the I<sup>2</sup>C specifications defined by Philips. # ACCESS.bus Development Kit # A.b-DEV-KIT ACCESS.bus is an open industry standard providing a simple and uniform way to connect up to 125 devices to a single port on a computer. ACCESS.bus features 100,000 bits per second data rate, hardware arbitration, dynamic reconfiguration, a comprehensive capabilities grammar to support generic software device drivers, and off-the-shelf, low-cost I2C Microcontroller technology. The A.b-DEV-KIT is an ACCESS.bus product development support package. It includes CATC's PC/AT A.b-125I ACCESS.bus controller board, an ACCESS.bus mouse, expansion box and cables and an 87C751 Microcontroller. The kit also includes a comprehensive software package, a user's manual and Hotline telephone support. The software package includes on-board microcode, an ACCESS.bus Manager that runs as a TSR under DOS and an ACCESS.bus Monitor and Control program. In addition the A.b-DEV-KIT software includes source code of ACCESS.bus generic software drivers for the host and ACCESS.bus devices software modules. #### **Features** - Complies fully with the ACCESS.bus standard - ACCESS.bus hardware package including - - The A.b-125I PC/AT ACCESS.bus Controller - An A.b Mouse - An A.b expansion box - A.b cables (2 ft and 4 ft) - A Philips 87C751 Microcontroller - A comprehensive software package including - - On-board ACCESS.bus Main Controller (MC) microcode - An ACCESS.bus Manager that runs as a TSR under DOS - An ACCESS.bus Monitor and Control program - Source code of an ACCESS.bus host generic software driver - Source code of a generic ACCESS.bus application layer software - Source code of ACCESS.bus devices software modules - A comprehensive A.b user's manual - Hotline telephone support The A.b-DEV-KIT includes ACCESS.bus accessories and comprehensive software # A.b-125I ACCESS.bus Controller Board #### **ACCESS.bus Interface** Controls a standard ACCESS.bus network. Provides two industry standard ACCESS.bus connectors, supplying 5V @ 0.75 A. #### **ACCESS.bus Network Size** Supports up to 125 ACCESS.bus devices. Physical distance up to 25 feet. With an external ACCESS.bus Buffer (optional) up to 250 feet. #### **System Interface** IBM PC/AT and compatibles. Uses the PC/AT 16-bit programmable input / output mechanism: User selectable I/O addresses - 0x250 to 0x25F 0x260 to 0x26F 0x350 to 0x35F User selectable interrupt - IRQ10, IRQ11 or IRQ12 #### **Physical** Power: +5V DC, 10 W max. Temp. Range: +0 to +50 degree C Board Size: 4.2" H x 6.5" W. #### Warranty 90-day. Return to factory for repair or replacement at manufacturers option #### A.b-DEV-KIT Software #### On-board MC microcode A real-time package that controls the operation of physical ACCESS.bus devices. #### **ACCESS.bus Manager** Runs as a TSR under DOS, communicates with the MC microcode and with the various device drivers. It routes control and application messages between the physical devices and their respective software drivers. #### **ACCESS.bus Monitor** A user-friendly, menu-driven program, displays user-selected ACCESS.bus messages and allows the user to control specific devices. #### Source Code License Source code of a generic ACCESS.bus software driver for the host. Source code of a generic ACCESS.bus application layer software. Source code of ACCESS.bus physical devices software modules. #### **Diagnostics** A comprehensive self test is performed on the board on power up. Diagnostics are run under control of the ACCESS.bus Monitor. Product specifications are subject to change without notice ## **Computer Access Technology Corporation** 949 Hillsboro Avenue, Sunnyvale, CA 94087 Tel: (408) 732 8910 Fax: (408) 730 1675 # ACCESS.bus PC/AT Controller Board A.b-125I #### **Description** ACCESS.bus is an open industry standard providing a simple and uniform way to connect up to 125 devices to a single computer port. ACCESS.bus features data rate of 100,000 bits per second, hardware arbitration, dynamic reconfiguration, a comprehensive capabilities grammer to support generic software device drivers, and off-the-shelf, low-cost I2C microcontroller technology. The A.b-125I is a PC/AT adapter board that serves as an ACCESS.bus master. It allows the connection of multiple devices to a single port on the PC. The board can be used in Desktop connectivity as well as in Control and Instrumentation applications. The board is based on a Philips 8xC654 microcontroller with I2C interface. The A.b-125I is offered with a comprehensive software package including on-board microcode and an ACCESS.bus Manager that runs as a TSR under DOS. #### **Features** - A highly integrated, half board design, uses a single 16-bit AT/ISA slot - Full compliance with the ACCESS.bus standard - On-board 8K bytes SRAM buffer memory - A comprehensive software package including - - An on-board ACCESS.bus Main Controller (MC) microcode - An ACCESS.bus Manager that runs as a TSR under DOS The A.b-125 allows the connection of multiple devices to a single port on the PC #### **ACCESS.bus Interface** Controls a standard ACCESS.bus network. Provides two industry standard ACCESS.bus connectors, supplying 5V @ 0.75 A. #### ACCESS.bus Network Size Supports up to 125 ACCESS.bus devices. Physical distance up to 25 feet. With an external ACCESS.bus Buffer (optional) up to 250 feet. #### **Buffer Memory** 8K x 8 bits (8K bytes) static RAM, #### **System Interface** IBM PC/AT and compatibles. Uses the PC/AT 16-bit programmable input / output mechanism: User selectable I/O addresses - 0x250 to 0x25F 0x260 to 0x26F 0x350 to 0x35F User selectable interrupt - IRQ10, IRQ11 or IRQ12 #### Software A comprehensive software package is provided with the board. The software includes the on-board ACCESS.bus Main Controller (MC) microcode and the ACCESS.bus Manager that runs as a TSR under DOS. CATC has additional ACCESS.bus software available including a Windows 3.1 version of the ACCESS.bus Manager, software device drivers, bus monitoring and control program and development tools. Call CATC for additional information. #### **Diagnostics** A comprehensive self test is performed on the board on power up. #### **Physical** Power: +5V DC, 10 W max. Temp. Range: +15 to +50 degree C Board Size: 4.2" H x 6.5" W. #### Warranty 90-day. Return to factory for repair or replacement at manufacturers option Product specifications are subject to change without notice #### **Computer Access Technology Corporation** 949 Hillsboro Avenue, Sunnyvale, CA 94087 Tel: (408) 732 8910 Fax: (408) 730 1675 October 1992 PRELIMINARY j <u>k</u>orto de a**ntik**a dorde Hasoapolika nasti obroši Hasoapolika nasti obroši in gill a liberal. Tall a liberal de la libe #### **Philips Semiconductors** # **Section 5**ACCESS.bus Application Notes & Articles Application Notes and Development Tools for 80C51 Microcontrollers #### CONTENTS | AN445 | ACCESS.bus mouse application code for the 8XC751 microcontroller | See Section 7 | | |--------------|------------------------------------------------------------------|---------------|--| | Issues in ( | ssues in desktop connectivity | | | | Finally, a p | olug-and-play solution | 295 | | | Special R | eport: ACCESS.bus Specs And Products | 297 | | | ACCESS. | bus: A New Peripheral Bus | 299 | | | Embedde | d control using ACCESS.bus | 301 | | | A PC-to-A | CCESS.bus interface card | 309 | | | Taking a n | new bus | 312 | | | Personal I | Digital Assistants: What's missing? | 318 | | | The portal | ble desktop: New connections for today's mobile user | 320 | | | Who's hop | oping on the ACCESS.bus? | 322 | | | ACCESS. | bus revisited—ending the peripheral connection nightma | ıre 324 | | | Seriously | serial | 207 | | #### Authors: Ata Khan and Greg Goodhue, Sunnyvale #### INTRODUCTION Desktop connectivity has become a major issue in system design. This paper identifies the criteria for evaluating a desktop bus or interconnect from data transfer rates and protocol flexibility to ease of implementation. It also compares the performance and cost implications of the typical desktop connectivity alternative. #### DESKTOP CONNECTIVITY Desktop connectivity is a method of connecting computer peripherals that are most often found on work surfaces, or desktops, to a host computer or workstation. Most often, desktop peripherals are low-speed Input/Output devices such as keyboards, mice, tablets, joysticks, and modems. This paper discusses devices which are usually dedicated to one computer, such as a PC, rather than high-speed peripherals such as laser printers and disk drives that are shared between users. # INTEREST IN DESKTOP CONNECTIVITY Current interest in desktop connectivity comes from both users and manufacturers of PCs and workstations. #### From the User's Side Connecting low-speed I/O devices such as keyboards, mice, tablets, moderns, and low-speed printers to a PC or a workstation has resulted in two problems for the user: a shortage of ports, and an excess of cabling. Shortage of ports is a big problem, especially with computers that have few slots or none at all. A computer with two serial ports, a parallel port, and a keyboard port is soon overwhelmed by peripherals requiring external expanders or switches of some sort. In the worst case, the user may be unable to use all the available peripherals at one time. Newer notebook computers exacerbate this problem by having fewer ports than desktop machines. An excess of cabling and connectors is one of the banes of connecting several desktop peripherals. By the time a user has figured out all the right cables, connectors, and gender changers, there is usually a small jungle on the desktop. From the user's point of view, there must be a better way. #### From the Manufacturer's Side Providing all the ports to which low-speed desktop I/O devices may be connected is expensive. Besides the actual hardware involved, valuable motherboard real estate is used and, especially in compact machines such as notebooks or pen-based computers, it is tricky to provide a lot of external connectors in very limited space. Also, the number of ports provided is usually either too few or too many, usually the former. Providing ports in hardware means connecting them to the CPU on the motherboard. Usually, this means each port must be provided with its own interrupt and dedicated address range. With systems, such as IBM type PCs, already being under severe constraints with regard to the number of I/O interrupts, adding sufficient ports for desktop use may become a problem. The CPU is the de facto manager of all these low-speed desktop peripherals; this means that signals from these slow devices are now moving on the same channels that high-speed devices such as disks are connected. Allowing bicycles on the *Autobahn* is a good analogy to the current system. Since each device has its own port, it also has its own device driver that "connects" the application software to the peripheral. This means that device drivers are hardware specific and different for each peripheral connected. Reconfiguring devices without powering down a system is a major advantage for both manufacturers and users, as anybody who has ever powered off a networked UNIX workstation knows. If it were possible to add and remove peripherals dynamically, such as different keyboards or tablets, without reconfiguring or re-booting the system, this would be a major operational advantage. ## CRITERIA FOR SELECTING A DESKTOP BUS Ideal criteria for selecting a desktop bus are outlined below: - Low-cost: Off-the-shelf, commodity type components a a minimum—ideally, just one—of these. - Daisy-chained: By allowing components to connect into each other, both of the problems the user has with a shortage of ports and an excess of cables are solved. - Dynamic reconfiguration: Hot-plugging and un-plugging of devices should be allowed without having to power down the system or re-boot it. This allows peripherals to be added, removed or defective ones swapped without long delays and inconvenience. - Uniform interfaces: With daisy-chained devices, the hardware interface is uniform by definition. This allows the same hardware layer drivers to be used for all peripherals. Software uniformity is also ideal but harder to implement and can, to some extent, be achieved through a layered protocol. - Sufficient bandwidth: While devices such as keyboards, mice, and tablets usually do not present much of a problem, devices such as modems and printers may. System simulation should be carried out to see that the chosen bandwidth meets these needs without causing excessive delays, lost data, or other problems. - Sufficient capacity: At the very minimum, six devices should be allowed (keyboard, mouse, tablet, modem, printer, misc.) and the cable specification should support this minimum - Inexpensive peripherals: Peripherals should be available that support this standard and are not significantly more expensive, if at all, than those available for other standards. - Open standard: There should be no royalties, patent issues, or licensing fees associated with the use of a desktop connectivity standard. ## CURRENT IMPLEMENTATIONS OF DESKTOP CONNECTIVITY Three major platforms implement desktop connectivity standards: IBM and compatible PCs, workstations, and Macintoshes. The PC platform and workstation platforms use dedicated I/O ports (RS-232 or other) for each peripheral being connected. Thus, for an IBM-style PC, each desktop peripheral has to have a port on the machine: one for the keyboard, one for the mouse, one for the tablet, etc. This gives rise to an onerous proliferation of cabling, connectors, and driver software where space is at a premium. In IBM-style notebook computers, there is usually a shortage of ports caused by limitations of space as well as power. The current solution is cumbersome, expensive to implement, and inelegant. Workstations use basically the same approach to desktop connectivity. However, there is some saving grace here that restrictions on space, power, and cost are less severe than PCs. The Macintosh™ solution, known as the Apple Desktop Bus™, is better than the PC and workstation solutions in the sense that it is more efficient in its use of space since peripherals can be daisy-chained and peripheral does not require a dedicated port. # ACCESS.bus<sup>™</sup>: A PROPOSED DESKTOP CONNECTIVITY STANDARD A desktop connectivity system for interconnecting low-speed peripherals was originally developed by Digital Equipment Corporation (Digital) in partnership with Philips Semiconductors and offered as an open standard. Called ACCESS.bus (a bus for connecting ACCESSory devices to a host system), the standard embodies most of the criteria of an ideal desktop connectivity standard. ACCESS.bus (also referred to as A.b) is a daisy-chained bus (see Figure 1) which allows up to fourteen devices (there are provisions for these devices themselves controlling other devices for expansion.) The total length of the cable is allowed to be eight meters and the data throughput rate of this bus is approximately 80 kbits/sec. ACCESS.bus is a fully open standard, without fee or royalty. The Advanced Computing Environment (ACE) initiative has designated A.b as an option in the Advanced RISC Computer (ARC) specification. Digital plans to organize a committee of user companies and A.b user groups to support the standard. #### **ACCESS.bus Structure** A.b is a layered protocol supporting a daisy-chained bus topology. There are three layers in the protocol (see Figure 2): - The Hardware (I<sup>2</sup>C) Protocol Layer: This layer is based on the Inter-Integrated Circuit, or I<sup>2</sup>C, serial protocol developed by Philips. This protocol defines a scheme for performing bus transactions with addressing, framing of bits into bytes, and acknowledgement of each byte by the receiver. - The Base Protocol Layer: This level is common to all A.b devices and builds on the Hardware layer to establish an asymmetric interconnect between a host computer and a number of peripheral devices. The A.b message envelope with control and status messages is defined here. - The Application Protocol Layer: In this layer, devices are differentiated with message semantics that are specific to particular kinds and classes of devices. In short, the mailman is I<sup>2</sup>C, the mail envelope is the Base Protocol, and the contents of the message are the Application Protocol. #### The Hardware Protocol (I<sup>2</sup>C) The Philips Inter-Integrated Circuit protocol, or I<sup>2</sup>C, is a 2-wire (clock and data) serial protocol which allows wire-AND connection of devices to the clock and data lines. The protocol allows devices to be either masters or slaves at any given bus transaction time (masters control the transaction and generate the clock signal). I<sup>2</sup>C is a symmetric multimaster bus where several masters can contend for the bus and an arbitration scheme resolves bus mastership without loss of data or re-transmission. Different clock rates are allowed on the bus with a cooperative synchronization scheme for the serial clock; this allows bus transactions to be performed between bus devices with different clock rates and without requiring any clock locking schemes. Device Connection: All devices are wire-AND'ed identically to the clock (SCL) and data (SDA) lines. Outputs must be open-drain or open-collector. Thus, any device may pull the bus low. When neither line is pulled low, the lines are held high by pull-up resistors. Every device must be able to sense the state of the line. In practice, this means a common ground level is required so that all devices see more or less the same input threshold. Bus Transaction: The bus is idle when both SDA and SCL lines are high after a transaction has been completed or after power-up. To initiate a transaction, a master device pulls the SDA line low. This represents a Start condition on the bus and all devices are required to sense its occurrence. Once the Start condition is asserted, the master then takes the SCL line low, and starts putting data on the SDA line by driving it low or leaving it high and pulsing the SCL line high and then back low. Data (SDA) is not allowed to change while the clock (SCL) line is high (see Figure 3). The master outputs the Address of the slave as the first byte transmitted (MSB first). After 8 bits have been transmitted, the slave, if one exists and recognizes its address, will pull the Data line low on the 9th clock bit time. This serves as an acknowledgement to the Master that the address has been received by the slave. A non-acknowledgment will cause the transfer to be aborted. <u>Bus Synchronization</u>: I<sup>2</sup>C provides a mechanism of synchronization that allows devices with different clock rates to work seamlessly with no required phase relationships between device clocks. When SCL is low, all devices (both masters and slaves) pull their own SCL outputs low and count out their low clock periods; when the low period expires, the devices release their SCL outputs. When SCL finally goes high, master devices count out their high clock periods until the master with the shortest clock period pulls SCL low again. Thus, the SCL low period is defined by the device with the longest low period and its high period by the device with the shortest high period. This cooperative synchronization allows all devices to use a common clock and allows slower peripherals to regulate the speed of the bus. <u>Multimaster Arbitration</u>: If two or more masters start transmitting on the bus, given that the clock is synchronized, each master then examines the state of SDA to see if its state is the same as the value of the bit it transmitted. The instant a master sees a difference, it knows it has lost arbitration and terminates its attempted transaction. Thus, arbitration between masters sending out different bus address values will always be uniquely resolved within the address transmission time. If masters send exactly the same message with the same contents to the same address, then the message is sent, but in cases where this is not desirable, software interlocks can prevent this situation. Since the arbitration is performed on a bit-by-bit basis, a form of priority is implied here where lower addresses (addresses with the first occurrence of a zero) have priority over addresses with ones in the same bit location (higher addresses). #### The Base Protocol The Base Protocol defines a number of control and status Messages that are common to all A.b peripherals. These are used for the configuration process in which peripherals are recognized and assigned unique address identifiers and then connected with appropriate device drivers to enable the application program to talk to them. A Message has five parts to it: - The first byte is the address of the destination or the receiver. - ii. The second byte is the address of the source or the transmitter. - iii. The third byte specifies whether the body of the message is control or data, if there are any sub-devices (0 to 3), and the length of the message body following in bytes. - iv. This part is the Message body, from 1 to 32 bytes. - A Checksum. This byte is the bit-wise XOR of all the preceding bytes in the message. While the detailed syntax and structure of the messages will not be discussed here, there are seven basic Messages defined as follows: Computer (Host) to Device: Reset Force device to Power-up state and default address IdRequest Ask device for its identification string (ID) AssignAddress Give device with recognized ID its unique bus address CapRequest Ask device to send Capability information Device to Computer (Host): Attention Inform of device presence and result of Power-up test IdReply Send device ID string to host CapReply Send Capability information to host The above features allow auto-addressing (eliminating hardwired addresses, jumpers, and switches) and hot-plugging. In general, operation is as follows: At Power-up, the host device transmits a general Reset to all devices (assigned the same default address at power-up). The devices initialize themselves, perform a self-test and send the result back to the host by an Attention message. On receiving an Attention message, the host sends an IDRequest message to the Default Address, each device at this address sends a unique 28-byte ID string back to the host; the IDReply. On getting the IDReply, the host is then able to assign an unique A.b address to the device. A Hot-plugged new device will send an Attention Message to the host seeking to be assigned an address. The host periodically checks the last logged configuration by sending IDRequest messages to all inactive devices. These actions allow the bus configuration to be dynamically altered. In this layer, the particular peripheral's device driver has to be found, loaded and connected to the application program. This is done by determining the device type and Capability Information by the CapRequest/CapReply messages. #### The Application Protocol Application level protocols are device-specific and the message semantics are different for different defined device types as well as different sub-types. While device drivers are different at this level, the Hardware and Base layers are independent of the device type allowing much firmware to be shared. Even at the Application Protocol level, a common definition structure is used for similar device types to encourage a common approach to writing A.b device drivers. So far, devices are classified into three broad types: - Keyboards: Up to 255-key devices are supported. Special function keys and annunciator support is built-in. - ii. Locator devices: Intended for mice, tablets, etc. This provides for devices with up to 15 degrees of freedom and up to 16 binary keys. - iii. Text devices: These are defined as data stream devices such as printers, modems, etc. Details of the semantics are in the ACCESS.bus specification. Flow Control (XON/XOFF) is provided with a character count being specifiable. #### **ACCESS.bus IMPLEMENTATION** The A.b controller must support all layers of the protocol for both the system and peripheral ends of the bus, the I<sup>2</sup>C hardware, the A.b Base layer, and the A.b Application layer. This is most efficiently done by using a microcontroller with an I<sup>2</sup>C interface with enough on-chip memory to implement the A.b firmware, thus implementing the entire protocol in one, off-the-shelf, commodity priced component. Philips manufactures a broad line of 80C51-based microcontrollers with built-in I<sup>2</sup>C interfaces and varying amounts of on-chip memory ranging from 2k bytes to 32k bytes of program memory. EPROM and OTP versions are available for system development as well as production. These microcontrollers provide all the intelligence for managing device communications for all 3 layers of the protocol. Of course, since the Base and I<sup>2</sup>C layers are common, this firmware may be reused. Even at the Application layer level, the common message structure allows some reusability. Since the 80C51 is an industry standard for microcontrollers, there is an abundance of third party support in the form of assemblers, compilers, development systems with In-Circuit-Emulation and symbolic debugging capability, EPROM programmers, etc. These tools are usually low-cost and are almost always PC-based. The physical connection itself is made by using a 4-pin connector that Molex and AMP will offer as a standard catalog item. The 4 wires are Power, Ground, SDA, and SCL. The shielded cable used has roughly 70 pF/meter of capacitance and up to 8 meters can be used. # ACCESS.bus VIS-A-VIS THE IDEAL AND VERSUS AN EXISTING STANDARD Comparing A.b to the list of ideal desktop connectivity attributes, we see that it fulfils them all except for the availability of low-cost off-the-shelf peripherals. A.b uses low-cost standard components, supports dynamic reconfiguration, is daisy-chained, and allows fourteen devices (and more via sub-devices). With a data rate of 80kbits/second, it is ample for the class of low-speed desktop peripherals for which it is intended. It presents a uniform hardware and software interface allowing re-usability of most firmware and has built-in error checking at both byte and message levels. ACCESS.bus will be implemented in forthcoming Digital workstations and, working with the ACE initiative, Digital and Philips will be striving to make it a standard for desktop connectivity. The issue of availability of peripherals presents a circular argument (which comes first) but, at this point, a keyboard, a mouse, and a graphic tablet are being developed for ACCESS.bus by major peripheral manufacturers. ACCESS.bus connectors are being developed by Molex and AMP and will be a standard item in their offerings. The closest existing alternative to ACCESS.bus is Apple Computer's ADB (Apple Desktop Bus, see Table 1). ADB is a daisy-chained bus, but has the following somewhat severe limitations versus ACCESS.bus: - ADB does not support hot-plugging or dynamic reconfiguration. - ADB has a maximum data rate of 10kbits/sec versus A.b's 80kbits/sec. - ADB has a 3 device limit versus 14 for A.b (and A.b can support more via sub-devices). - ADB is a closed, proprietary bus, whereas A.b is fully open. - ADB is specified to work over a 5 meter length, while A.b can go 8 meters. Table 1. ACCESS.bus vs. Apple Desktop Bus | FEATURE | APPLE<br>DESKTOP<br>BUS | ACCESS.bus | |---------------------------------|-------------------------|--------------| | Hot<br>plugging | Limited | Full support | | Transfer rate | 10kbit/sec | 80kbit/sec | | Maximum<br>number of<br>devices | 3 devices | 14 devices | | Maximum<br>length | 5 meters | 8 meters | | Availability | Proprietary | Open to all | #### CONCLUSION The issue of desktop connectivity for PCs and workstations has been neglected and solved piecemeal so far. ACCESS.bus represents the first coherent, well-defined, desktop connectivity standard which is solidly backed and, based on what it offers both users and manufacturers, should become established as a market standard as well. ACCESS.bus is a trademark of the ACCESS.bus Industry Group; Macintosh and Apple Desktop Bus are trademarks of Apple Computer Corp. # Finally, a plug-and-play solution With ACCESS.bus™, you can connect up to 125 peripherals to one PC or workstation port without having to reconfigure, quit your application, or rehoot. ACCESS.bus is a new industry-standard technology that provides a simple, low-cost way to connect keyboards, joysticks, tablets, high-speed modems, and other peripherals to a single port on your computer or workstation. Already supported by Microsoft DOS and Windows, Digital VMS, and Sun Solaris 2.X operating systems, ACCESS.bus is also backed by other industry leaders such as Compaq, Fujitsu, Honeywell, IBM, Intel, Key Tronic, Lexmark, Logitech, Motorola, National Semiconductor, and Philips. lug in your peripherals and keep going. That's it. No need to quit your application, load special software, reconfigure, or reboot—you don't even have to issue a command. In fact, because ACCESS.bus uses one port to consolidate all your peripherals, you don't even have to consider the complexities of multiple jacks, UARTs, slots, or options. eclaim a chunk of your office. By eliminating that unsightly cord snarl behind your computer, you'll gain more workspace. More room for other devices. More room to create. # **Philips Semiconductors** **PHILIPS** magine the possibilities. Whether you go down the hall, across the country, or around the world, you'll be able to plug your peripherals into any computer at hand. No need to hunt for compatible models. Everything will be interchanged effortlessly. And to that one computer or workstation, you'll be able to connect as many of the same types of peripherals as you need—or a broad range of them—into a single port. The potential in new applications is limitless. In workgroup applications such as education, entertainment, and video conferencing, ACCESS.bus enables you to exchange ideas faster and more dynamically by plugging peripherals into a common monitor. Because ACCESS.bus allows you to join in or drop out at will, computer games become multiple player games. By simply plugging into the system you can join forces or become a sudden new challenge from the opposition. In simulation, you'll experience and learn from the decisions of your colleagues the moment the action takes place. The possibilities are endless. ## ow is this technology possible? Based on ACCESS.bus microcontrollers, readily available from companies such as Philips, ACCESS.bus is supported by an industry-wide trade group. ACCESS.bus software intelligence resides in the host computer and in each peripheral. As soon as you plug it in, the peripheral device identifies itself and, almost instantaneously, the host gives each peripheral a unique name. In this way, all your devices can easily communicate over one computer line. Whether you add one peripheral or as many as 125, it's as simple as plugging it in. # C all for more information about the new industry **standard**. The ACCESS.bus Industry Group, or ABIG, is an industry-wide association formed to create and maintain the ACCESS.bus standard so tomorrow's technology can be in your hands today. For more information about ACCESS.bus or how to become an ABIG member, call Philips at 1-800-447-1500, ext. 1080, or call ABIG at 408-991-3517 (fax 408-991-3773). **Enormous Gains for Developers** Computer vendors — Save precious space on the motherboard, especially in notebooks and other limited-space devices where the fewer external connectors required, the simpler your production and inventory. No more multiple jacks, slots, options, communications ports, or UARTs. ACCESS.bus uses only one port to consolidate the peripherals needed to run an application. Device manufacturers — ACCESS.bus requires only one standard driver for different devices, so you save time and expense during driver development. Systems integrators — Offer plug-andplay freedom. As technology gets more complex, you'll be able to offer simpler human interface solutions. ACCESS.bus presents no limitation on communications ports, slots, or jacks. ACCESS.bus is a trademark of the ACCESS.bus Industry Group. All other product or service names mentioned herein are trademarks of their respective owners. ©Philips Electronics North America Corporation, 1993. Printed in U.S.A. #### Special Report: ACCESS.bus Specs And Products # - Procuetive Ws Products Prototype Design The development of ACCESS.bus, a communications protocol for connecting multiple, low-speed I/O devices to a single computer port, and the formation last June of the ACCESS.bus Industry Group (ABIG) is spawning creation of a rapidly growing number of hardware and software products based on the ACCESS.bus' connectivity specs (see chart below). ACCESS.bus was jointly developed by Digital Equipment Corp. and Philips Semiconductors and is now owned and supported by ABIG, who is promoting the new bus as an industry standard. To date, up to 125 peripheral devices, including keyboards, mice, scanners, digitizers, and bar code readers have been made to operate independently on a single computer port. At the hardware level, ACCESS.bus uses the I2C (Inter-Integrated Circuit) serial bus developed by Philips several years ago to simplify automotive electronics and other distributed control systems. This serial bus is designed to carry 1 bit of information at a time on a single data line. Today, a host of low-cost I<sup>2</sup>C components are readily available to handle the logical complications associated with bitlevel handshaking. The physical medium for ACCESS.bus is a shielded cable with four wires for handling serial data (SDA), se- rial clock (SCL), power (5V), and ground (GND). The SDA and SCL lines work together to define information carried on the bus, and the host computer drives the 5V power line with a minimum of 50 mA to supply peripheral devices (peripherals can also be externally powered). A typical ACCESS.bus device has two connectors, permitting two or more peripherals to be daisy-chained together on the bus (handheld devices can have a captive cable joined to the bus trunk with a T-connector). This shielded connector has 4 pins I<sup>2</sup>C technology supports clock rates up to 100 kHz and the maximum ACCESS.bus data transfer rate is approximately 80 kbits/s. The ACCESS.bus communications protocol has three layers: I<sup>2</sup>C, Base and Applications. The I<sup>2</sup>C Protocol defines a symmetric, multi-master bus on which arbitration among contending masters is effected without losing data. I<sup>2</sup>C provides cooperative synchronization of the serial clock for exchange of data between bus partners with different maximum clock rates, defining a bus transaction scheme with addressing, framing of bits into bytes, and byte acknowledgement by the receiver. Base Protocol establishes an asymmetrical interconnect between host computer and peripheral devices. The host is the ACCESS.bus manager, and data communication is always between host and peripheral, never between two peripherals. While the I<sup>2</sup>C Protocol establishes mastership between the sender or receiver of a bus transaction, Base Protocol defines the format of an ACCESS.bus message envelope, which is an I2C bus transaction with additional semantics, including checksum reliability control. Base Protocol also defines a set of seven control and status message types used in the configuration process. The high-level Application Protocol defines message semantics specific to particular functional types of devices. To date, Application Protocol have been established for keyboards, locators and text devices and is intended to define the simplest set of functions from common, industry-standard interfaces. Further, device-specific Application Protocol models will be defined by the ACCESS.bus Reprinted with permission from the April 1993 issue of EE Product News, © 1993 Intertec Publishing Corporation, Overland Park, KS. April 1993 297 #### Special Report: ACCESS.bus Specs And Products Industry Group; and, of course, any vendor can implement a special device protocol within the general message envelope defined by the Base Protocol. Electrically, host and peripheral devices are connected to serial data (SDA) and serial clock (SCL) lines in a wired-AND logic configuration, which can be implemented by connecting data and clock output stages of each bus partner to the SDA and SCL lines, respectively, through open-collector or open-drain transistors. Standard I<sup>2</sup>C components include these output stages on-chip. Significance of the wired-AND logic is that any attached bus partner can force either of these lines to LOW (GND); and when there is no output from any bus partner, lines are held HIGH by pull-up current sources in the host. Every bus partner can sense the level on both of these lines. ACCESS bus can be adapted to any platform and presently requires use of a controller board in the computer, but within 12 months, computer motherboards containing the necessary ACCESS bus circuitry are expected to begin to appear. Software drivers are also available for DOS and Windows. For additional information on ACCESS.bus v2.0 specs and on membership to ABIG, contact: ACCESS.bus Industry Group, 415-112 N. Mary Ave., Sunnyvale, CA 94086, (408) 991-3517, FAX (408) 991-3773. April 1993 298 #### **ACCESS.bus: A New Peripheral Bus** Author: Michael Burton # Midnight Engineering Would you like to be able to plug a keyboard, two mice, a trackball, a modem and a printer into a single port on your PC? And then, while the computer is still powered up, unplug one of the mice and plug in a bar code reader? You can do all of this and more with ACCESS.bus. Digital Equipment Corporation and Philips have joined forces to propose this new open desktop connectivity standard. The ACCESS.bus Industry Group (ABIG) has been formed to regulate and promote the new bus. ABIG members include DEC, Honeywell, Logitech, Philips and Sun Microsystems, to name just a few. There are many advantages to the ACCESS.bus standard. It is low cost, dynamically reconfigurable, relatively inexpensive and the interface is uniform for all devices. ACCESS.bus is also an open standard, unlike Apple Computer's comparable Apple Data Bus (ADB). #### **Bus Description** ACCESS.bus allows multiple peripheral devices to be simultaneously supported on a single computer port in a daisy chain fashion, somewhat like a SCSI daisy chain. These peripherals may operate simultaneously at transfer rates of up to 125,000 baud, with a maximum data throughput rate of approximately 80,000 baud. This is ideal for low speed peripherals such as keyboards, modems, trackballs and mice. A maximum cable length of 8 meters is permitted. A four pin, shielded rectangular connecter is used on ACCESS.bus cables. The maximum amount of power available is 1 amp at 5 volts. The bus can support up to 125 peripheral devices, but the normal practical limit is 14. By way of comparison, the Apple Data Bus supports 5 meters of cable and 3 devices with a data rate of 10,000 baud. ACCESS.bus is a layered protocol. There are three layers: the hardware protocol layer, the Base protocol layer and the Application protocol layer. Using a postal analogy, the hardware protocol layer is the mail carrier, the Base protocol layer is the envelope and the Application protocol layer is the contents of the envelope. The hardware protocol layer is based on the I<sup>2</sup>C (Inter-Integrated Circuit) serial protocol, which is directly supported by the Philips 8051 family of microprocessors (80CL410, 80C552, 80C652, 80C528, 87C654 and 87C751). This protocol defines a scheme for performing bus transactions, including message addressing, the framing of bits into bytes and the acknowledgment of each byte by the receiver. The Base protocol layer is a software protocol that is common to all ACCESS.bus devices and that builds on the hardware protocol layer to establish the connection between the computer and a number of peripheral devices. The Base protocol layer specifies device power-up, identification, addressing and the message envelope for device-specific data and control information. The Application protocol layer is a software protocol that differentiates message contents for specific kinds and classes of devices. #### **Hardware Protocol Layer** The hardware I<sup>2</sup>C protocol layer is a 2-wire (clock and data) serial protocol that allows wire-AND connection of peripheral devices to the clock and data lines. Any device may be either a master (controlling the transaction and generating the clock) or a slave for any given bus transaction. Several masters can contend for the bus and an arbitration scheme resolves bus mastership without data loss or retransmission. The clock rates for various peripherals may vary widely, since the bus has a cooperative serial clock synchronization scheme. #### **Base Protocol Laver** The Base protocol layer contains definitions for a number of control and status messages that are common to all ACCESS.bus peripherals. The messages are used for the configuration process, where peripherals are recognized, assigned unique address identifiers and are then connected with appropriate device drivers to enable an application program to talk to them. A message has five parts to it: - The first byte is the address of the destination or receiver. - The second byte is the address of the source or transmitter. - The third byte specifies whether the body of the message is control or data, if there are any sub-devices (0 to 3) and the length of the message body. - 4. This part is the message body, which can be from 0 to 127 bytes in length. - This last byte is the checksum, a bit-wise exclusive-or of all the preceding bytes in the message. There are eight base messages, shown below. #### Computer to Device Messages - Reset—Force the device to its power-up state and to its default I<sup>2</sup>C address. - IdRequest—Ask the device for its identification string. - AssignAddress—Tell the device with a matching identification string to change its address to a new address. - CapRequest—Ask the device to send its capabilities information. #### **Device to Computer Messages** - Attention—Inform the computer that the device has finished its power-up/reset tests and that it needs to be configured. - 2. IdReply—Reply to an IdRequest with the device's unique identification string. - CapReply—Reply to a CapRequest with a fragment of the device's capabilities string. - IfError—Invalid checksum or premature end of message detected. Copyright © 1993 by Midnight Engineering. Reprinted with permission. #### ACCESS.bus: A New Peripheral Bus When a peripheral device powers up or resets, its initial device address is always 6Eh. The Base messages are used to reset this device address to a unique address between 02h and 7Eh (125 assignable addresses). #### **Application Protocol Layer** Application protocol layer messages are specific to the peripheral device and the message layouts are different for each device type, as well as for each device sub-type. This means that the device drivers are different at this level, but since the hardware and Base protocols are device-independent, much of the firmware support code can be shared by different devices. Even at the Applications protocol level, a common message structure is used for similar device types, so that a common approach can be used in writing ACCESS.bus device drivers. To date, peripheral devices for ACCESS.bus have been classed into three broad categories: **Keyboards**—May have as many as 255 keys. Special function keys and annunciators are supported. Locator devices-Includes pointing devices such as mice, trackballs, graphic tablets, etc. Provides for devices with up to 15 degrees of freedom and up to 16 binary keys. **Text devices**—Devices that support data streams (e.g., modems, printers, etc.). #### What ACCESS.bus Means to You ACCESS.bus is a coherent, well-defined desktop connectivity standard. It is solidly backed by DEC, Philips and others in the industry and it offers much to both users and peripheral manufacturers. Since it is so new, there are plenty of opportunities for entrepreneurs to implement ACCESS.bus devices with fewer direct challenges from the big guys. Peripheral devices that already use an 8051 microprocessor only need to change their I/O firmware, so the impact of designing for a new bus can be minimized. Watch out, though—Microsoft and others are starting to pay attention to ACCESS.bus, so the window of opportunity is getting smaller. #### **ACCESS.bus Access** The ACCESS.bus Industry Group will provide free information, including the ACCESS.bus Specification, to anyone who asks for it. It costs nothing to join ABIG (as a company) if you plan to develop an ACCESS.bus peripheral. ABIG's address is: ACCESS.bus Industry Group 370 Altair Way Suite 215 Sunnyvale, CA 94086 408-991-3517 or FAX: 408-991-3773 At least one company provides and ACCESS.bus Development Kit, at a cost of \$1500. The kit includes a controller board, a Logitech ACCESS.bus mouse, an expansion box, two cables, a Philips 87C751 microprocessor, a comprehensive software package and documentation for everything. Their address is: Computer Access Technology Corporation 3375 Scott Blvd. #410 Santa Clara, California 95054 800-909-CATC (2282) 408-727-6600 FAX: 727-6622 Michael Burton is a Senior Software Engineer, at Key Tronic Corporation, Spokane, WA. # THE COMPUTER **APPLICATIONS JOURNAL** June 1993 — Issue #35 # COMMUNICATIONS **ACCESS.bus Design Tips** High-speed Modem **Basics** **Designing With IR LEDs** **Embedded Interrupts** on the '386SX **Component Selection** ssues # Embedded Control Using ACCESS.bus Macintosh users have long been used to plugging multiple peripherals together with a single kind of cabling system using Apple's Desktop Bus. Now, ACCESS. bus promises to clean up the cable clutter for PCs, too. ## FEATURE ARTICLE David Wyland ouldn't you love to have a perfect serial interface for general-purpose instrumentation and control that works every time you plug it together? One with all the aggravations associated with RS-232 eliminated? Could you appreciate an interface ten times as fast as 9600 bps, but automatically slows down if it needs to? Could you find some use for the real estate saved by using TTL signal levels instead of ±12 volts (so you don't need space or power for level converters)? Would you like to simplify your system interconnects by using a multidrop bus connection? Would you like a cabling solution where you can solution where you can have one kind of cable for all situations? Would you object to never wiring a null modem again, or never again pondering if CTS/RTS/DTR/DSR are wired to the wrong pins? Would you like this interface to be an openly defined industry standard, supported by lots of devices and by several large companies? This wonderful, utopian bus actually exists! The ACCESS.bus meets the standards I outlined in my "wish list." It is a serial bus, but there are no "settings" to concern yourself with. The source (Master) sends data to the destination (Slave) in 8-bit bytes with an acknowledge at the end of each byte. The ACCESS.bus transfers data at up to 100 kbps (400 kbps in the future). It features automatic slowdown by either the sending or receiving device as required. It uses TTL signal levels (0 and +5 volts) for data transmission. It is a multidrop bus using modified modular-phone cable with a simple 4-wire connection. ACCESS.bus devices can also be hot plugged, meaning that it lets you safely add or remove devices from the ACCESS.bus while it is running. It doesn't even have addresses to set or DIP switches to fiddle with! The CPU automatically assigns addresses at reset or when a device is powered up. Best of all, the ACCESS.bus is on its way to being an industry standard for PCs. The ACCESS.bus is a result of the work by DEC and Philips/Signetics to create a desktop bus for the PC. The goal of the desktop bus is to simplify the cabling to keyboards, mice, graphical tablets, lightpens, and so forth ACCESS.bus is a software overlay on the ubiquitous PC bus standard, so it can easily leverage off the momentum already established for that standard. The PC bus has over 150 chips available that support it. There June 1993 302 Figure 1—Based on FC, ACCESS bus uses a simple four-wire interface that provides not only a data channel, but also power to peripherals. The proposed modular connector locks in place and eliminates orientation confusion. are at least eight 8051 microcontroller chip derivatives available with PC bus UARTs on them. There is also an PC UART—the PCD8584—that you can lash to the processor of your choice. #### **ACCESS.BUS BASICS** The ACCESS.bus is a serial bus that uses a four-wire interconnection standard. The cable called out in the standard is a modified modular-phone cable (see Figure 1) and is shielded to minimize RFI. The cable contains two signals—serial clock and serial data. The other two wires are power and ground. The power line supplies +5 volts at up to 1 amp for powering small devices such as mice, keyboards, and so forth, directly from the cable. The ACCESS.bus is a half-duplex bus and uses a multidrop protocol where each device on the bus has a unique address. Up to 124 devices can share the bus, with addresses 00h, 50h, and 6Eh reserved. The maximum bus capacitance of 400 pF restricts the number of devices and constrains the cable length to 8 meters. This capacitance limit ensures a rise time of less than 1 $\mu s$ when termination resistances of less than 2.5k ohms are used. You connect devices to the bus in parallel. The Serial Data line (SDA) carries data transmissions which are clocked into the receiving device by the Serial Clock line (SCL). If the receiving device needs more time, it holds down the SCL line until it is ready for more data. The specification limits this hold time to 2 ms. The sending device holds the data bit unchanged while the clock is high except for start and stop conditions. The sending device initiates a message by changing the Issue #35 June 1993 SDA line from high to low while SCL is high, and terminates the message by taking the SDA line low to high while SCL is high. Since any device can send a message to the CPU at any time, collisions are possible. This happens when multiple devices see the bus in a "not busy" state and start sending a message simultaneously. The devices do collision detection to sense such events. Each one checks to see that the data on the bus is the same as the data it is putting on the bus. In case of a collision, the two devices will eventually try to send different data bits. Since the bus is open drain, the one sending a low level wins, so the device trying to send a high level detects a bus error, stops, and retries its transmission later. Plugging a new device on the bus might corrupt a message in progress, but the same collision detection mechanism will also sense such a corruption. Collision detection coupled with the open-drain nature of the bus are the key features of the standard that allow hot plugging. The ACCESS.bus moves data in 8bit bytes similar to RS-232. However. byte transfers over the bus use the I2C bus protocol. I2C defines byte transfers as follows: The transmitter sends the most-significant bit first, followed by an acknowledge bit supplied by the receiver (see Figure 2). Messages begin with a Start condition and end with a Stop condition. This differs from RS-232 that has Start and Stop bits for each byte. The ACCESS.bus provides a standard that organizes groups of bytes into messages, defines how to assign addresses to slave devices, and defines all messages as writes-from CPU to slave or from slave to CPU. The ACCESS.bus messages vary in length from 1 to 127 bytes. Figure 3 shows the message protocol. Each message consists of a destination Figure 2—In FC, serial data (SDA) is sampled when the serial clock (SCL) is high. The basic packet of information consists of a destination address, a R/W flag, data, and start/stop framing. A simple ACK/NACK status is sent back by the destination device. The Computer Applications Journal June 1993 303 ``` Listing 1-The main 80C652 CPU message transfer code handles the master side of the ACCESS bus interface :Subroutine to send a message from CPU to I/O device Enter with slave address, length, pointer to bytes of data Set to Master mode, send Start bit by writing 68h to Control reg. Check for valid start Send I/O address using SBYTE Send CPU address = 6Eh using SBYTE Send length using SBYTE Send data bytes using SBYTE Calc.checksum = XOR of all bytes from slave address through last data byte Send checksum using SBYTE Send stop bit Clear from Master mode, set to slave mode (default): Set Assert Acknowledge by writing 04h to Control register :Subroutine to send one byte Write byte to data register Wait for acknowledge from Status reg.: can be interrupt response :Error routines ARB: On Send arbitration error, send stop bit, clear from master mode and restart at SEND. NAK: On Send not acknowledge, send stop bit, clear from master mode and restart at SEND. TIMO: On Timeout, exit with error code :Subroutine to read a byte from I/O device to CPU READ: Set slave address Set message length = 81h = 1 byte with command bit = 1 Set command byte = 10h (Read Request) Call SEND to send Read Request message Call RECV to receive message :Subroutine to receive a message from I/O device to CPU RECV: Note: CPU in slave mode as default Receive CPU Address = 6Eh Receive master (sender) address Receive message length Receive data bytes Receive checksum but don't acknowledge yet Verify checksum Send acknowledge if checksum OK, not if not OK Receive STOP condition :Subroutine to receive one byte Wait for Interrupt Exit; Return byte on interrupt, set interrupt ``` address, a source address, a byte count, a control/data flag bit, the message with 1–127 bytes of data, and a checksum. The PC UART transfers each byte automatically, and each byte receives an acknowledge from the destination device. The PC UART hardware handles message initiation, byte acknowledge, speed control, and message termination. If the Control/Data flag in the byte count field is a 1, the message is a command. The operation code is the first byte immediately after the byte count. Opcodes in the range of 00h through 7Fh are available for general use. For instance, I use opcode 10h as a Read Request command to an I/O device. The ACCESS.bus reserves opcodes from 80h through FFh for control functions. These control functions and their reserved codes include: Reset (F0h), Identification Request (F1h), Assign Address (F2h), Attention (E0h), Identification Reply (E1h), and Interface Error (E3h). #### AN ACCESS BUS SYSTEM ACCESS.bus systems are simple to design and work with. You have only two signal wires and one power wire to deal with. The I2C bus is an open-drain pull-down bus with a single pair of pull-up termination resistors, which are typically installed at the CPU end. You determine the resistor value from the maximum-rated drive current (3 mA) for the I2C drivers. The resistor value also determines the data transmission speed since the resistor current charges the line capacitance. A 2k-ohm resistor works well, as shown in Figure 4. An optional 100-ohm resistor in series with each driver helps kill noise. The +5 V is provided through a fuse or a current-limited regulator. A current-limited regulator has the advantage of automatic recovery with no fuse to replace after a failure. The choice of resistor size and fuse method is about all the hardware design you must do. A good way to explore the ACCESS.bus is to use it in a system. I'll make a simple system with one CPU and three I/O ports. Each port has 8 bits of digital input and 8 bits of digital output. Figure 4 shows a block The Computer Applications Journal Issue #35 June 1993 diagram of my system. I use four microcontroller chips: an 83C652 as the primary CPU and three 87C751s as I/O device controllers. These chips are variants of 8051 microcontroller chips with I<sup>2</sup>C UARTs. I use the microcontrollers to implement the ACCESS.bus communication protocol over their I2C connections. The 83C652 is a 40-pin device with external EPROM and RAM. These features make it useful as the central CPU. The 87C751s are 20pin, 300-mil components with internal EPROMs, the I<sup>2</sup>C interface, and two 8bit bidirectional I/O ports. These devices will serve as the I/O device controllers in my prototype. The three 87C751s each provide peripheral device control. The I<sup>2</sup>C interface uses two of the three bits on Port 0, Port 1 receives the 8 bits of data input; and Port 3 supplies the 8 bits of data output. Note that both ports are bidirectional. If you need more data I/O, you can use Port 1 as a bidirectional 8-bit data bus, and use Port 3 as an 8-bit address bus. This allows up to 256 bytes of data I/O from this single device As you can see, this is a simple system in terms of hardware design. Unlike RS-232, there are no level converters, no baud rate configuration switches, and the connector pinout is simple and fixed for all devices. The bus connection method simplifies cabling and means there is only one PC UART at the host end rather than one for each I/O device. This also means you can add I/O devices to the system without adding hardware to the CPU. The bus connection method is possible because messages can be more than one byte long. In ACCESS.bus, there is a multibyte message between Start and Stop codes that contains the addresses of the source and destination of the message. This allows several devices to share the same bus. The hardware design of our ACCESS.bus system is simple: the software makes it work. The software converts data into ACCESS.bus messages for transfers between the CPU and I/O devices, and sets up the addresses of the devices when they power up. ``` Listing 2—The message transfer code for the 87C751 VO Controller handles the remote data acquisition and control. ``` :Subroutine to send a message from I/O device to CPU ``` SEND: Enter with slave address, length, pointer to bytes of data Set Master mode: Write 50h to Config = req bus master, 100 kbps Send I/O address using SADDR Send CPU address = 6Eh using SBYTE Send length using SBYTE Send data bytes using SBYTE Calc. checksum = XOR of bytes from slave addr through last byte Send checksum using SBYTE Send stop bit Set to Slave mode: Write 90h to Config. Reg. (default mode) ;Subroutine to request bus mastership and send address SADDR: Wait for ATN bit in Control Register, go to SAERR if error Go to send byte routine Set bit counter to 8 Write MSB to Data Register Rotate left for next bit Wait for bit sent: wait for ATN in Control Register Decrement bit count and loop back to SBYTE+1 if not zero Set to receive mode to receive ack: Send AOh to Control Reg Wait for ATN Exit: Return acknowledge status :Error routines SAFRR: On Send arbitration error, send stop bit, clear from master mode and restart at SEND. On Send not acknowledge, send stop bit, clear from master mode and restart at SEND. TIMO: On Timeout, exit with error code :Subroutine to receive a message from CPU to I/O Device RECV: Enter in Slave mode (This is the default mode) Receive slave address: call RDACK Receive CPU Address = 6Eh Receive message length Receive data bytes Receive checksum but don't acknowledge yet Verify checksum Send ack if checksum OK and slave addr compares; otherwise not Receive STOP condition Check for Read Req. command = command with Operation code 10h If Read Req.t, get byte of input data from Port 1 and call SEND Exit :Subroutine to receive one byte RBYTE: Set bit counter to 7, clear accumulator Wait for bit Get bit, clear ATN Rotate to LSB Decrement bit count and loop back to RBYTE+1 Wait for last bit Get bit, don't clear ATN Rotate to LSB Send acknowledge Wait for ATN Check for errors Exit ``` Issue #35 June 1993 The Computer Applications Journal #### **ACCESS.BUS PROGRAMMING** There are two areas to the software design for an ACCESS.bus system: the set of routines that send data to and receive data from the remote devices, and the initialization code that assigns the soft addresses to the devices when the system powers up. Initialization sequences are also required when a device is plugged onto a bus that is already running. Let's look at the operating routines first. The CPU sends messages to an I/O device, and I/O devices send messages to the CPU. The message protocol is the same in both of these cases. Any I/O device can send a message to the CPU at any time. For example, a keyboard sends key data to the CPU whenever you press a key. The sending device is always the master and the receiving device is always the slave. My 4-MPU system can write bytes from the CPU to the output port of a selected I/O device, and it can read bytes from the input port of a selected I/O device. To write a byte from the CPU to another device, the CPU must send a message with the appropriate address. In this case, the CPU sends a data message to the desired I/O device address. The I/O device receives this data and writes it to its output port. Figure 4—Many 87C751-based I/O ports may be added to the 83C652-based ACCESS.bus system with just a single pair of wires. For the CPU to read a byte, it sends a command message called Read Request to the I/O device, and it responds with a data message containing the data. The Read Request command is a single-byte command message which is the opcode. I use a user-definable opcode (10h) for the Read Request. #### **CPU PROGRAM** The I<sup>2</sup>C controls in the 83C652 and the 87C751 are different. The 83C652 contains a full I<sup>2</sup>C UART. The 87C751 has a less-capable interface, so the program does the serialize, descrialize, and timing-control functions. Listing 1 shows the 83C652 routines for message transfer. The CPU writes a byte to the output port of an I/O device by sending a Read Request command (10h) to the I/O device. In turn, the I/O device responds by sending a one-byte message with data to the CPU. The 83C652 PC interface has four 8-bit registers: Control, Status, Slave Address, and Data. The Control register controls PC communication. It enables the PC UART, sets the maximum bit rate, sends Start and Stop states, sends byte acknowledge messages, and enables an 8051 inter- Figure 3—The standard ACCESS bus message packet is based on FC, but includes additional information. The packet consists of a destination address, source address, length, data bytes, and a simple checksum. rupt for status changes. The Status register provides a 5-bit status code indicating function completion or error. The Slave Address register provides the response address for messages that are sent to the CPU. The protocol sets the CPU Slave address to 50h. The Data register sends and receives 8-bit bytes of data. #### I/O DEVICE PROGRAM Listing 2 shows the message transfer program for the 87C751. When the CPU writes a byte to the I/O device, it sends a one-byte data message. The I/O device program receives this message from the CPU and writes it to Port 3. When the I/O device receives the Read Request from the CPU, it reads the data on the input port and sends a message to the CPU. The 87C751 PC interface has four registers: Configuration, Control, Status, and Data. The Configuration register defines whether the PC interface is in Master or Slave mode. It also holds the timer value for the maximum baud rate. The Control register sends the Start and Stop conditions to the bus and indicates attention and data ready conditions. The Status register indicates the status of Start and Stop conditions. The Data register provides one bit of storage. The 87C751 program provides data serialize and deserialize functions, slave address recognition, and individual bit timing. These routines complicate the program but reduces the cost of the silicon in the system. The Computer Applications Journal Issue #35 June 1993 It is also practical since the 87C751 is used as a simple I/O controller and the program hasn't much to do except tend the PC interface and pass the data to the digital I/O port the '751 serves. #### **SOFTENING UP THE ADDRESSES** An address is assigned to each I/O device by the CPU. The I/O device stores the address and uses it when communicating with the CPU. When the CPU sends a message to the I/O device, this address is part of the message. If the destination address matches the address stored in its register, the I/O device accepts the message; otherwise it ignores the message. When the I/O device sends a message to the CPU, the message includes the source address so the CPU can tell who sent it. The I/O device address is also called the slave address. The CPU has a fixed slave address of 50H. The CPU assigns each device on the bus a unique I/O address as part of the initialization sequence. The CPU also assigns an I/O address to each device plugged into the bus while the bus is running. The device plugged into the bus notifies the host of its existence, and the host assigns it a unique address. Each device sends an Attention command to the CPU asking for an address assignment when the device powers up or is reset. The Attention routine in the CPU receives the command and sends an Identification Request command to the default I/O device slave address, 6Eh. The device responds with an Identification Reply command. This consists of a 29-byte ID string including device type, model, and so forth, plus a unique 32-bit number, typically a random number. The random number lets the CPU distinguish between identical devices. The CPU records this data, picks the next available soft address and sends it with an Assign Address command to the device. The CPU sends a copy of the identification string with the new device address to ensure that the correct device receives it. As a final precaution, the I/O device sends a Reset command to its own address in case another identical device had an identical 32-bit random Listing 3—Each device on the ACCESS.bus is assigned an address when it's connected or when the bus is reset. The CPU initiates the process. ``` :Setup Code at Reset ``` #### DECET. Write C9H to Control Register to enable I<sup>2</sup>C, interrupt, 100 Kbaud Write 6Eh to Slave Address register Loop to send a Reset command to each I/O device address, 01h through FEh Exit to main program loop :Interrupt routine to service Attention Command from slave at 6Eh to CPU at 50h #### ATTN Send Identification Request command to 6Eh (default slave address) Wait for Identification Reply. If no response in 40 ms, exit Put identification string in device table. Select next available slave address. Send Assign Address command with ID string and new slave address Exit number and was assigned the same slave address. In this case, the arbitration ensures that only one device sends a message at a time. One device sends its reset command first, and the other device receives it before it can issue its own reset command. The sequence for soft address initialization of the CPU is summarized below and is shown in pseudocode in Listing 3. The initialization of each I/O device is the complement of this, and is shown in Listing 4. - CPU broadcasts a reset command and all devices revert to default address: 6Eh. - Each device sends an Attention message, informing the CPU of its existence. - CPU sends an ID Request command to the default slave device address: 6Eh. - All devices try to respond with their ID data containing a unique 32-bit number. - I<sup>2</sup>C bus arbitration causes the messages to be received one at a time - CPU records the ID data and random ID number for each device. - CPU sends an Assign Address command with its new slave address to each device. - Each device sends a reset to its assigned address to solve any duplicate device problems. The Attention routine in the host #### Listing 4—ACCESS bus Psuedocode for 87C751 I/O Controller for Soft Address Initialization ``` RESET: Set to Slave mode: Write 90h to Config. Reg. (default mode) Write 00h to Control Register Set 6Eh as default slave address Send Attention command to CPU at 50h Wait for Identification Request command from CPU Send Identification Reply command to CPU with 32-bit random ID # Wait for Assign Address command. Check Id Reply against ID string. If match, accept new slave addr. Send Reset command to new slave address. If arbitration error, wait for N+50 usec, where N is 8 LSb's of 32-bit random number If reset received at new slave address while waiting, start over at RESET. Exit to main program loop ``` Issue #35 June 1993 The Computer Applications Journal June 1993 307 that does the soft address assignment automatically is the same one that handles hot plugging. When you plug a new device into the bus, it powers up in a reset state and issues an Attention command. The CPU responds with an Identification Request, and slave address assignment proceeds like at system power up. One of the side benefits of automatic address assignment is the CPU generates a record of all devices currently active on the bus. Each time you add a new device to the bus, the CPU automatically updates this table. The CPU does not automatically update the table when you remove a device, however. If you want this feature, you must add an additional background scan routine. ### WHERE CAN I GET MORE INFORMATION? Information on the ACCESS.bus is available from the ACCESS.bus Industry Group. They will supply you with the latest detailed specification of the bus. Another good source for both ACCESS.bus and I<sup>2</sup>C bus information is the Philips Semiconductor Data Handbook for 80C51-based 8-bit Microcontrollers. It contains information on both buses as well as the I<sup>2</sup>C chips that can be used with them. Computer Access Technology provides boards and software for ACCESS.bus. You can quickly set up a system using a PC as a host with their boards. David Wyland specializes in Scheduled Inventions, combining his background in analog and digital system architecture to run his consulting group. Contact him at The Wyland Group, 15213 Bowden Ct., Morgan Hill, CA 95037, (408) 778-3860. #### CONTACT ACCESS.bus Industry Group 415-112 N. Mary Ave., Ste. 265 Sunnyvale, CA 94086 (408) 991-3517 Philips Semiconductors 811 E. Arques Ave. P.O. Box 3409 Sunnyvale, CA 94088-3409 (408) 991-3518 Computer Access Technology Corp. 3375 Scott Blvd., Suite 410 Santa Clara, CA 95054 [800] 909-2282 © Circuit Cellar INK, The Computer Applications Journal. Reprinted with permission. #### A PC-to-ACCESS.bus interface card ### A PC-to-ACCESS.bus Interface Card by Robert Clemens and Tom Stockebrand The card and software described here are for a first-generation interface that we supplied to DEC and Signetics as a means of quickly getting an ACCESS.bus interface in a PC. ACCESS.bus is a handy tool for solving the problem of not enough hardware ports. It also allows for adding or removing peripherals while the system is running (hot plugging). For example, you may want to navigate through Windows using a mouse while in one application, but use a digitizing tablet or track ball in others. You can have them all available to plug in in any combination and still have serial ports available. #### **BACKGROUND** A few years ago, Ken Olsen at DEC asked our group to solve the problem of hooking a bunch of desktop peripherals together without the rat's nest of wiring that is usually needed for this task. Our A/D group had adopted the Philips I<sup>2</sup>C bus as the means to build our display system prototypes. We were exploring the idea of extending it to the world outside a PC board. Since it is a fairly fast (100 kbps) serial bus that can be daisy chained and hot plugged, it was very attractive. It turned out that the workstation group had been thinking of the same thing, so the project was born. Our group in Albuquerque worked on the hardware, the Display Systems Group back in Westford, Mass., did the software architecture, and Robert did the software design and construction. We soon joined forces with Signetics (now Philips) and they have taken over the work (along with the ACCESS.bus Industry Group) of getting the ACCESS.bus supported and encouraged. The hardware problem was that the specs for the I<sup>o</sup>C bus required a 1- $\mu$ s maximum rise time. This limits the capacitive load to 300 pF with the specified 3k-ohm pullups. This is not very much head room if any significant amount of cable is to be driven. The hardware solution that we hit upon was to drive the bus with current sources rather than with resistors. That way the rise time specification could be met with a load as high as 800 pF. Peter Sichel and the design team at DEC worked Figure I—The core of the PC-to-ACCESS.bus interface board is a Philips PCD8584 PC serial-to-parallel converter chip. Issue #35 June 1993 The Computer Applications Journal June 1993 309 #### A PC-to-ACCESS.bus interface card out a fairly spare software protocol, and other details were worked out such as standardizing on a plug and a low-capacitance cable. At this time, the ability to put two formal hosts on the bus isn't in the spec. It is possible, though (more information on this is available from Robert). In fact, we think providing a means of hooking two or more CPUs together is one key to success for the concept. Therefore, there is a requirement to be able to shut off the current sources in all but one of them so as to limit the current that has to be sinked by the IPC hardware. The board described here has current limiting using PTC resistors, but no direction limiting. A revised version should provide current direction limiting or just disable the local power supplied to the bus when the current sources are turned off. #### HARDWARE DESCRIPTION Figure I contains the schematic of the PC-to-ACCESS.bus interface card. The core chip on the board is a serial-to-parallel converter for the PC bus made by Philips called the PCD8584. It is very similar to a UART but provides for the particular sophistication needed by the PC protocol. It is driven with a standard PC address decode structure. There are current sources on the card for powering the bus and a means to turn them off by setting a port bit and also to do a software reset. In this first-generation board, we limited the current that would run down the power supply wire by means of PTC resistors. They work, but are slow and expensive. A better way is to provide the +5 V with a regulator chip that is current limited to 0.5 A, adding fuses "just in case." The latest ACCESS. bus specification does not require the +12-V option as provided in this design. The detailed specs are outlined later in this article. #### SOFTWARE DESCRIPTION I use a base address of 300h as an example in this discussion. An IORead from address 300h gets the status of the I<sup>2</sup>C interface. An IOWrite to address 300h issues a command. A Read from 301h gets the I<sup>2</sup>C data into the I<sup>2</sup>C and a Write to 301h puts data out to the I<sup>2</sup>C bus. An IOWrite to address 302h loads the port bits. Setting the LSB (bit zero of address 302h) to 1 causes a software reset (it is cleared with a hardware reset and must be cleared again after a software reset). Setting bit one of port 302h turns the current sources OFF. The duties of a driver or application that wants to talk to an ACCESS.bus network are the address configuration and management of devices during power-up of the host, recognition and configuration of new devices as they are plugged in, and management of messages to and from ACCESS.bus devices and PC-based applications. Management of the devices is the same in implementations for all platforms. The handling of messages to and from host-based applications are platform specific. As mentioned in main article, in order to maintain a basic working ACCESS. bus system, a table of devices must be built in software that keeps track of a device's current running status, its 1<sup>2</sup>C address, ID string, capabilities string, and a current pointer into the capabilities string. Also, a global variable for bus status must be maintained because a forced reset of the bus causes certain time-dependent actions to occur, and it is possible for a misbehaved device to create a bus error that can affect the state of the other devices on the bus. Listing I shows some basic program structures and condition states that are useful when writing the software. The last components needed are the routines that parse the message stream, install the appropriate hardware I/O and interrupt routing, and a link into the platform's timebase to drive time-dependent activity. A Turbo Pascal source file is available on the Circuit Cellar BBS that works with this hardware design to implement a simple ACCESS. bus system for an IBM-compatible PC. This system allows viewing messages from devices, sending a message to a device, and starting/managing a reset sequence. Listing I—There are several data structures and condition code definitions that are helpful when writing ACCESS bus support code. ``` Recommended device data structure: AB DEVICE = record status : integer: : integer address I D : string[30]; Capabilities : string[MAXCAPABILITIESLEN]; CapOffset : word: Recommend global bus conditions: BusReset Software is starting a reset sequence BusAssignAddress Software is assigning addresses to devices BusConfigured Software can begin normal operation BusError Error has occurred, attempt to reset bus Recommended device conditions for each device are: DevReset. Device is being reset or no device is at this address DevWait Device is busy, do not send message DevConfirm Confirm device is still connected DevConfigured Device is ready for normal operation DevError Device has a problem ``` The Computer Applications Journal Issue #35 June 1993 #### A PC-to-ACCESS.bus interface card #### **DETAILED HARDWARE INSTRUCTIONS** #### **JUMPERS** There are three headers on the board, each with a single shorting jumper. One is to select one of the six Interrupt Request Levels [IRQ 2-7]. The other pair is to set the unit to provide either 12 volts or 5 volts to the RJ-11-style output connectors. There is also one DIP switch to be used in selecting the address group to which the card will respond. #### IRO The IRQ header has six pairs of pins. The upper row of pins is connected to the output of the –INT line from the PCB 8584 serial-to-parallel converter chip through an inverter. The lower row of pins is connected to IRQ 2–7 in order across the plug from left to right. In order to use the Interface card, one IRQ should be selected by moving the jumper clip to the appropriate horizontal position and using it to jump the upper to the lower pin at that point. #### **POWER TO THE LOADS** Just behind the output sockets on the card are a pair of three-pin headers. A jumper on the upper one selects whether +5 V or clock (SCL) is applied to pin 2 of the output socket. A shorting block on the lower header determines whether +12 V or SCL is applied to pin one (the bottom pin) of the output sockets. The output sockets are wired in parallel. The two voltages are supplied through positive temperature coefficient resistors, used as resetting fuses, which have a resistance of 0.5 ohm and will allow 0.5 A to pass before starting to heat up and limiting the current that can be supplied externally. For 5-V operation, the jumper clip on each header should short the center pin to the upper pin. For 12-V operation, they should each short the center to the lower pin on the header. If the jumpers are in the wrong position (either connecting the power to the wrong line or supplying both pins 1 and 2 with power, or neither) no harm will be done, but the system will not work. #### **ADDRESS SELECTION** The only DIP switch on the board is for selecting the port address for the interface card, modulo 4. The switch position labeled "1" is unused. The seven switches marked 2-8 enable the corresponding lines for address comparison with the corresponding address lines on the PC bus. For example, if the base address for the card is to be 300 (the usual case) then all switches should be closed, grounding their respective inputs to the address comparator, except number 8 which will then be pulled high internally. Internally, the address comparator's "9" input is held high at all times. This is because address bit 9 must be a one for all port accesses on a PC. Since address bits 0–1 are not fed to the comparator, its output will be true for addresses 300 through 303. The low address (e.g., 300) is for reading or writing data to the ACCESS bus. The next one (e.g., 301) reads or writes the command/status register and the third (e.g., 302) writes from PC to the two data port register bits for doing a software reset (D0) or turning off the current sources (D1) The lowest address in the available space is 200 (all switches closed or "On") since this corresponds to bit 9-1 alone. The highest address is obtained with all switches open yielding 3FCh as the base address. This address range can be shown as 01000000x to 11111111xx in binary, where xx are the low-order bits used to select the port addresses 0-3 as described above. #### JUST THE BEGINNING As ACCESS.bus catches on and makes your desktop a lot less cluttered, a board such as the one we describe here can be your ticket to exploring the possibilities ACCESS.bus opens up. Have fun. Robert Clemens has done extensive programming for MIDI interfaces including sound editors for the PC. He also does embedded application programming in 8051-type microcontrollers using I<sup>2</sup>C and ACCESS.bus protocols. He is available at MediaMultiTech, P.O. Box 426, Durango, CO 81302, (303) 247-4726. Tom Stockebrand spent 28 years working for DEC, mostly in the capacity of product design engineering and management for peripherals such as tape drives, communications interfaces, and displays. He did the original DECtape design, and his group did the original DEC VT50 series of terminals. In the 1980s, he ran an A/D group developing very high resolution displays at DEC's Albuquerque facility. He now has a small engineering consultancy called LGK Corp. which tries to provide a one-stop garage shop for getting breadboards and prototypes designed and built. Issue #35 June 1993 The Computer Applications Journal June 1993 311 # ANDREW SEYBOLD'S **CUTLOOK** # ON PROFESSIONAL COMPUTING Volume 10, Number 12 ISSN: 0895-3821 July 1993 #### **An Outlook Reprint** This article is reproduced here exactly as it originally appeared. It has not been abridged, revised, or updated since its first publication. *The Outlook* has prepared this reprint at the request of Philips Semiconductors. Andrew Seybold's Outlook on Professional Computing reserves the right to alter formatting as space requirements dictate, but no changes have been made in the textual material reprinted. ACCESS bus is a serial bus that supports "hot" attachment of up to 125 devices to a PC via a daisy-chained type of connection. Each device has its own address and is "recognized" by the system. #### **Technology** ### Taking a New Bus Since IBM introduced the PC in August of 1981, there have been continuous advances in the state of the PC. The first Intel-based machines came complete with 64K of RAM (expandable to 256K), a choice of monochrome or Color Graphics Array (CGA) monitors, and sported a cassette-player interface. Over the years, we have seen video choices expand to include EGA, MGA, VGA, Super VGA, and beyond. Cassette players gave way to 10 MB hard disks, and then 20, 40, 60, 80 and now 200 MB drives. Hard disk interfaces have evolved from SASI to IDE and SCSI. And hard disk drives are now available with 500 or more megabytes of storage. Memory configurations have increased to 4, 8, 16 and more megabytes of RAM. CPUs have gone from 5 MHz, 8-bit processors to 66 MHz, 64-bit Pentium devices. Computer motherboards now include serial ports, parallel ports, video, memory caches, and other "standard" features not even contemplated only a few short years ago. (continued on page 3) © 1993 by Pinecrest Press, Inc., P.O. Box 917, Brookdale, CA 95007, Telephone (408) 338-7701 Reproduction in whole or in part without express written permission is prohibited. July 1993 312 Vol. 10, No. 12 Andrew Seybold's Outlook on Professional Computing 3 #### Keyboards Keyboards also went through a major change—from XT to AT-compatible units with added functionality. Then we began adding pointing devices such as mice and trackballs—first by making use of existing serial ports and, more recently, with the addition of the PS/2 mouse port. But the computer itself has changed more than the keyboard and mouse interfaces. Certainly, there have been changes in the types of keyboards, and a number of different types of pointing devices are available. But the basic connection to the PC has not changed since the introduction of the IBM-AT systems in the mid-1980s. Why should we change something that works okay, is inexpensive to produce, and has become almost as standard as an AC power plug? Sure, there are differences in types of keyboards, and you can't simply plug any pointing device into just any type of computer. For the most part, however, this one area of the computer has been very stable. There's no reason to muck around with it, right? Wrong! #### **Apple's ADB Bus** Meanwhile, Apple introduced the Macintosh computer and, over the years, developed the Apple Device Bus (ADB) that provides a pair of connections on the back of the computer. Users have choices as to how they connect their keyboard and mouse or trackball. Since the ADB is designed to handle multiple devices (up to 3 recommended according to Apple), the keyboard can be plugged into the computer and the mouse plug can be inserted into the second ADB socket on the computer, or it can be plugged into the keyboard. To connect devices using the Apple Bus, the computer must be turned off. With IBM-compatible machines, once the system has been booted, if a keyboard or mouse is disconnected, the system must be re-booted when the device is plugged back in. # Enter Digital Equipment Corporation A number of years ago, engineers at Digital Equipment Corporation decided to work on a universal keyboard and pointing device architecture for its workstations. The result of this design effort was a new bus architecture that makes use of the I<sup>2</sup>C (Inter-Integrated Circuit, invented by Philips Semiconductor) serial bus to provide an efficient, cost-effective method of connecting devices. DEC incorporated this new bus architecture in the Maxine, the DEC Personal Workstation 5000. DEC then decided to give it to the industry and an association to promote. Thus, the ACCESS.bus Industry Group was formed in 1992. This association has more than 50 members, representing vendors from all parts of the computer industry. Among other activities, this group has a technical workgroup preparing a high-speed ACCESS.bus specification to extend the speed of the bus to between 500K and 1 MBit/second as a first step. Keyboard manufacturers such as Honeywell, Keytronics, and Lexmark, Logitech, a manufacturer of mice and trackballs, as well as many major computer vendors, are either members of the association or have attended meetings and indicated a willingness to take part in this association. #### What Is ACCESS.bus? The technical description of ACCESS bus is that it provides a simple, uniform way to link a local computer (terminal, PC, or workstation) to a number of low- Important: This page contains the results of proprietary research. Reproduction in whole or in part is prohibited. For reprints call (408) 338-7701. Andrew Seybold's Outlook on Professional Computing July 1993 speed I/O devices such as a keyboard, mouse, tablet, or a 3-D tracker. In more direct terms, it is a serial bus that permits attachment of up to 125 devices to a PC via a daisy-chained type of connection. And it does so in such a way that each device is "recognized" by the system and each device can be connected and disconnected while the system is running. #### A Simple Demonstration Our first exposure to ACCESS.bus was a demonstration of a game running on a standard PC. The keyboard and mouse looked like standard devices. Upon closer examination, however, we saw they were connected to the system by telephone-type plugs, and the keyboard had not one, but two receptacles. The game was a Pong-type, where a "paddle" is controlled by the mouse. The player is supposed to hit the bouncing ball with the paddle, bouncing it against a wall. The ball returns to be hit again. After we watched this elementary game for a few minutes, a second mouse was plugged in, and the game immediately split into a two-player game. Each player could control his own paddle with his own mouse, and the game became interactive. This interactivity was prompted by one action, and one action only—the insertion of the second mouse plug into an ACCESS.bus connector. A third mouse was connected, and a third player was automatically added to the game. Finally, a fourth device was added (this time a trackball), and we had four players all chasing the same ball, trying to hit it to the other players. This is perhaps a simplistic example of ACCESS.bus, but it does demonstrate the power of this new technology. Adding any type of device causes the control program to recognize what type of device it is, and what function it will perform in the system. Want to have two keyboards and two mice on the same system, both with the same capabilities? No problem! #### **Using ACCESS.bus** I left the demonstration with a demo kit that contained two mice, a trackball, a keyboard, a standard Industry Standard Architecture (ISA) card, and some software. The ultimate goal of the ACCESS.bus folks is to have the chip set built directly onto the systems board. But in the interim, there is an ISA card that contains the chip set and into which ACCESS.bus connectors are plugged. This card can be installed in any standard Intel-based PC. The existing keyboard connector on the PC is jumpered to the ACCESS.bus board and the first ACCESS.bus connector is plugged into the card. Once the software is installed, the system works just as you would normally expect, with a standard PC keyboard and mouse. Our installation was accomplished by connecting a cable from the PC card to the keyboard, and from the keyboard to a multi-port connector. From this connector, we plugged in a mouse and fired up the system. It worked just as our original keyboard and mouse did, and the standard mouse functions normally. Next, we plugged in the trackball, since our preferred pointing device is a trackball. Now we had one keyboard, a mouse, and a trackball connected to the system. Without having to do anything but plug them in, both the mouse and the trackball functioned perfectly. Since we had an extra mouse, we connected it, too. This is the set-up we've been using for the past few weeks. We have a mouse to the right of the keyboard, one to the left (I'm left-handed), and a trackball, also mounted to the right. No matter which pointing device we reach for, it works. Important: This page contains the results of proprietary research. Reproduction in whole or in part is prohibited. For reprints call (408) 338-7701. July 1993 314 #### Vol. 10, No. 12 #### Andrew Seybold's Outlook on Professional Computing 5 #### Other Devices Each device on the ACCESS.bus has its own address and each device is "recognized" by the system. If we plug in a keyboard, the system knows it is a keyboard. It recognizes a mouse, a trackball, and any other type of device it knows about. The possibilities are endless. In its present form (release 2.1), ACCESS.bus also recognizes tablets, a 3-D tracker, and handheld scanners. This technology has the potential to provide a universal bus for many other types of input devices, and could be used for security devices, as well. Since the connectors are inexpensive telephone-type plugs, and since existing hardware includes cabling to permit devices to be plugged into a multiple connector box, each user of a system could have a unique device with a specific built-in ID. #### **Applications** Such capabilities could be used to enable features and functions, permit access to different types of services, and even to disable the system completely if a particular device was disconnected. Further, since this bus supports "hot" connections, the PC would not have to be re-booted if a new device or security module was added. If you let your mind wander a bit, you can envision the variety of devices that could be connected to share this bus. With 125-device capability, it would not be too farfetched to think modems, scanners, and various types of printers would share this bus—with a single connection to the PC. Think of the number of slots (or lack thereof) that could be designed into PCs to make use of the ACCESS.bus. A single connector on the motherboard would enable the use of, and support for, up to 125 devices—each of which is simply plugged into an empty socket on the ACCESS.bus cable. Add a new device-specific driver, and off you go! SCSI busses work on the same premise, except that the Small Computer Systems Interface (SCSI) bus is designed for fast data exchange and can only support a total of 8 devices. Why use the SCSI bus for all the lower-speed devices you would like to add? #### **Technical Information** The current ACCESS.bus specification is release version 2.1. Hardware specifications have been formalized and can be easily implemented by any vendor that wants to make use of this architecture. #### The Demo Kit A demonstration kit of ACCESS.bus hardware and software is currently available from Computer Access Technology. As mentioned above, this kit contains a standard ISA quarter-length card, cabling, a keyboard, two mice, and a trackball. The keyboard is made by Honeywell (its keyboard division has been sold to Keytronics, which is continuing to support ACCESS.bus). Installing the system is easy. The ISA card mounts in the PC, a jumper is provided to connect the PC keyboard port to the card, and the ACCESS bus cabling is run from the card. In our configuration, we ran a single ACCESS bus cable from our floor-mounted DEC MT Tower system up to our desktop. We then connected it to the keyboard, and used the other connector on the keyboard to connect to a 4-way junction box. At the junction box, we connected both mice and the trackball. We installed the software and were off and running. Having more than a single pointing Important: This page contains the results of proprietary research. Reproduction in whole or in part is prohibited. For reprints call (408) 338-7701. 315 July 1993 Andrew Seybold's Outlook on Professional Computing July 1993 device available is nice. There are times when we really like the trackball, but there are also situations where we prefer a mouse. #### **Cabling and Connectors** ACCESS.bus uses four-pin, shielded MOLEX SEMCONN or AMP SDL, modular-type connectors (these resemble the standard RJ-11 telephone clip-in plugs, but are a little larger). The entire bus only requires four wires—ground, +5 Volts, Serial Data (SDA), and Serial Clock (SCL). The cables themselves are shielded, and devices can be located up to eight meters (about 25 feet) from the computer. In addition, provisions have been made for ACCESS.bus devices to be powered externally, if required. RF filtering and power shielding are also specified. #### The Devices Every device on the bus must be a microcontroller with I<sup>2</sup>C interface and behave as either a master transmitter or a slave receiver, exclusively, as defined in the I<sup>2</sup>C specification. Initially, all devices respond to a default power-up address. During the configuration process, the computer assigns a unique address to every device on the bus. ACCESS.bus supports multiple like-devices without switches or jumpers. #### The Message Format A message transmits information between a device and the computer or between the computer and one or more devices. These messages are a minimum of four bytes in length and are one of two types—a Device Data Stream or Control/Status Stream. The difference is indicated by the protocol flag. The maximum theoretical length of a message is 131 bytes (127 data types and four bytes for overhead). Using this message format, each device provides the proper type of information to the computer, and each device is totally independent of others. Hot connections are permitted, and software can be used to recognize new devices as they are added to the string of connected devices. #### ACCESS.bus Implications The ACCESS.bus Industry Group, the organization promoting this new bus architecture, has been working with many companies in the hope that ACCESS.bus will become the new *de facto* standard within the PC industry. It has gathered support from almost every sector of the industry, including both hardware and software vendors. The hope is that one of the major companies experimenting with the bus will stand up and announce to the world that they are going to be providing ACCESS.bus as a standard part of their hardware platforms in the future. The organization has done its homework extremely well. We believe this bus architecture should be implemented within the PC industry. Once the first vendor stands up and announces its intention to make use of ACCESS.bus, all the other vendors will include this capability into their products, as well. #### **Standards** Unlike some of the other standards that have been brought to the PC market by a specific vendor, ACCESS.bus has been introduced by an organization of many different vendors. Once accepted by the industry, it will find its way into Important: This page contains the results of proprietary research. Reproduction in whole or in part is prohibited. For reprints call (408) 338-7701. July 1993 316 #### Vol. 10, No. 12 #### Andrew Seybold's Outlook on Professional Computing 7 next-generation products in short order. Companies are developing mice, trackballs, tablets, keyboards, and other devices that will be ACCESS.bus-compatible and will add functions to the PC. Existing PCs can be retrofitted with the ACCESS.bus via the ISA card. Thus, this is not a case of a new technology making existing equipment obsolete. We would like to see Microsoft build ACCESS.bus recognition into its operating systems, or at least make it available as an add-in option. Major hardware vendors investigating the use of ACCESS.bus will then step up to the microphone and endorse both the concept and the accomplishments of the ACCESS.bus Industry Group. #### Conclusions We have looked at the ACCESS.bus technology, investigated the vendors pursuing its implementation in mainstream computing, and can find no reason for not implementing it. Once ACCESS.bus becomes accepted and is included as part of all PCs being built, it will open new worlds of connectivity. Consider that ACCESS.bus can be used in servers, desktops, portables, and even handhelds. It could be built into PCMCIA cards to provide ACCESS.bus connectivity to handhelds. Users could carry their own ACCESS.bus ID module with them to activate access to data, or to permit the computer to reconfigure itself. In the education market, ACCESS bus provides multiple device access so that a single PC can accommodate multiple users. Adding a second joystick would change an educational game from a computer-vs.-player mode to a player-vs.-player mode, and additional security could be included. In the business market, the adoption of ACCESS.bus means that many different types of peripherals can be easily added to virtually any computer. Adding devices would not require opening the machine and installing a new card. In the game market, vendors could easily adapt their products to recognize how many players were on-line and modify the game accordingly. In short, ACCESS.bus is a technology whose time has truly come. It is stable, inexpensive, easy to implement, and extends the functionality of the computer. We believe it should be embraced by the entire PC industry. Come on folks! We know it's out there and we want it! -Andrew M. Seybold #### For further information, contact: Philips Semiconductors 811 E. Arques Avenue P.O. Box 3409 Sunnyvale, CA 94088-3409 408-991-3518 ACCESS.bus Industry Group 415-112 N. Mary Avenue Suite 265 Sunnyvale, CA 94086 408-991-3517 Computer Access Technology Corp. 3375 Scott Blvd., Suite 410 Santa Clara, CA 95054 408-727-6600 800-909-2282 Important: This page contains the results of proprietary research. Reproduction in whole or in part is prohibited. For reprints call (408) 338-7701. #### Personal Digital Assistants: What's missing? # ANDREW SEYBOLD'S **CUTLOOK** # ON MOBILE COMPUTING Volume 1, Number 10 ISSN: 1066-8845 October 1993 An Outlook Reprint- The following article is reproduced here as it originally appeared. Formatting has been altered, but no changes have been made in the textual material. *The Outlook* has prepared this reprint at the request of Philips Semiconductors. #### **Personal Digital Assistants** ### What's Missing? Well, we now have two PDAs on the market (four if you count the two EO devices). While Apple is touting that it has sold more than 50,000 of its Newton MessagePads, we have yet to find anyone who has been able to successfully use one to communicate to or from desktop computers or to access an e-mail system. This is also true of the Tandy Z-PDA (Zoomer). There are several reasons for this. First, a pen-based system is not conducive to interacting with a text-based (ASCII) mail system since each and every character has to be recognized and converted from electronic ink to ASCII before it can be sent. Second, the wired communications options provided with today's PDAs are not easy to implement, nor is there a viable wireless link. While pondering these issues and trying to determine how one would go about providing a handheld PDA that would enable users to access e-mail services, a possible solution occurred to us. We have passed this idea on to several potential PDA vendors. It is a simple solution and one that could be implemented quickly. #### Wireless and ACCESS.bus Our cover story in the July 1993 Outlook on Professional Computing (Vol. 10, No. 12) was about a new bus architecture called ACCESS.bus. We described this new bus as follows: "The technical description of ACCESS.bus is that it provides a simple, uniform way to link a local computer (terminal, PC, or workstation) to a number of low speed I/O devices such as a keyboard, mouse, tablet, or a 3-D tracker. In more direct terms, it is a serial bus that permits attachment of up to 125 devices to a PC via a daisy-chained type of connection. And it does so in such a way that each device is "recognized" by the system and each device can be connected and disconnected while the system is running." The on-board portion of ACCESS.bus is a custom chip and a single telephone-type connector—the amount of real estate it would take up and the cost of implementation would be of little concern to design teams. Once outfitted with the ACCESS.bus I/O system, a PDA could be connected to multiple devices via a single connector. And since the system supports "hot" connect/disconnect, and the software is smart enough to recognize that one or more devices have been attached or removed, it could be incorporated to provide any number of fully automatic functions. © 1993 by Pinecrest Press, Inc., P.O. Box 917, Brookdale, CA 95007, Telephone (408) 338-7701 Reproduction in whole or in part without express written permission is prohibited. October 1993 318 #### Personal Digital Assistants: What's missing? #### Andrew Seybold's Outlook on Mobile Computing October 1993 For example, suppose a PDA was equipped with the ACCESS.bus connector and was normally used as a pen-based handheld device. The user could also have a small keyboard that, when attached to the PDA, would automatically put the PDA into a keyboard input mode. We can take this one step further and build an external keyboard on top of a wireless modem (housed in the same form factor), and then connect this combination through the ACCESS.bus. You could take this still further and have the software recognize that this device combination had been attached, and thus automatically launch the communications program. #### The Next Step Now that we have ACCESS.bus in our PDA, it will recognize the device that is plugged in and make the proper connection for the device. Such a device could be a wireless modem, a wired modem, a combination of both, or any other device we might want to use with our PDA. What about a direct link via ACCESS.bus to your desktop computer? It is our understanding that in the near future many desktop PC companies will offer systems with an integrated ACCESS.bus system. In the meantime, ACCESS.bus is available as an ISA card that can be added to any IBM-compatible machine (the ACCESS.bus Station by CATC). A real advantage of using ACCESS.bus is that a single connector located on a PDA can be your ACCESS to any number of devices (pardon the pun). All a user needs to do is to plug in a device—the system knows what the device is and how to work with it. #### **Up for Grabs** We believe that PDAs will need to have keyboards for at least the next year or two. We also believe that the keyboard does not necessarily have to be an integral part of each PDA—it can be an external unit that is connected only when access to e-mail and remote information is required. We also believe that ACCESS bus is an architecture ideally suited to provide not only the keyboard connection, but also connections for modems, direct to PCs, and to any number of other devices. We have not changed our minds about the importance of PCMCIA slots on such machines, but most of them will only have a single PC card slot. An ACCESS.bus connector, in addition to the PCMCIA slot, would certainly add value to the PDAs. The next several generations of PDAs are on the drawing boards now. There is still time to take advantage of this new technology. Maybe some day people will be willing to walk around with PDAs that only have a pen as an input device, but for now we are still betting that most mobile users have computers and readily recognize the advantages of being able to access their e-mail and other information when they are not at their desks. The combination of ACCESS.bus, a keyboard, and a wireless modem seems like a natural fit to us. If you want to find out more about ACCESS.bus, you can contact the Industry Group at: ACCESS.bus Industry Group 370 Altair Way, Suite 215 Sunnyvale, CA 94086 408-991-3517 fax 408-991-3773 —Andrew M. Seybold Important: This page contains the results of proprietary research. Reproduction in whole or in part is prohibited. For reprints call (408) 338-7701. October 1993 319 #### The portable desktop: New connections for today's mobile user Reprinted from PC Week • February 14, 1994 # PGWEEK The Portable Desktop New connections for today's mobile user BY MICHAEL R. ZIMMERMAN Mobile computing will become more practical this year as several budding standards make their way from spec sheets to products. ISA PNP (Plug and Play), Access.bus, and PCMCIA's ExCA (Exchangeable Card Architecture) are three standards that will make such things as docking a notebook, connecting multiple peripherals, and "hot swapping" PCMCIA cards nobraiers. "These integral pieces will make mobile computing more pleasurable," said Andrew Seybold, publisher of Outlook On Mobile Computing, a newsletter based in Santa Clara, Calif. "It's happening now." #### Access.bus Perhaps the most unfamiliar player in the trio of standards is Access.bus, which can support scores of peripheral devices through a single SDL connector. Users can run an Access.bus-compliant notebook's SDL connector, which is slightly wider than a typical RJ-11 jack, through numerous daisychained multiport boxes to support as many as 125 peripheral devices. Parts of Access bus have been used in computers and consumer electronics for years. The standard, as it applies to PCs, incorporates two intelligent logic chips and software drivers that support hot swapping—the ability to add or detach devices without having to first turn off or reconfigure the PC. Access bus detects which devices have been added or detached and automatically reconfigures the system. A handful of companies, such as Santa Clara-based Computer Access Technology Corp., currently manufacture Access.bus-compliant adapter cards and drivers for desktop PCs. But Eldad Granot, director of marketing and a member of the Access.bus Industry Group, in Santa Clara, said several large notebook makers also are gearing up to release portable systems equipped with Access.bus technology built onto the motherboard. In addition, Microsoft Corp. is working with OEMs to announce its support for Access.bus at the WinHEC show in San Francisco this month, said Keith Kegley, product manager for new product development in Microsoft's hardware group. The Redmond, Wash., software giant may embed Access.bus drivers on the CD ROM for its Chicago operating system, he said. Although the drivers would not be part of the installation setup, users would be able to load the drivers when needed. Most major PC makers, such as IBM, Compaq Computer Corp., and Dell Computer Corp., are currently evaluating the technology and may stand up with #### The portable desktop: New connections for today's mobile user Microsoft in an endorsement this month, sources said. #### Plug and Play The PNP spec is more popular because of influential supporters such as Microsoft and Compaq. Like Access.bus, it benefits both desktop and notebook PCs, but it enhances each type of system differently. When fully implemented in a desktop, for example, users can add and detach add-in cards without having to adjust jumper switches or load special drivers. Notebook users will benefit from being able to dock a PNP-compliant notebook into a compliant docking station without having to shut down or reconfigure the notebook first. This is called "hot docking." "[Hot docking] will be a nice feature because you won't have to interrupt what you're doing to connect to the network," said Scott Kelly, technical-support engineer for product development at Itron Inc., a software developer in Spokane, Wash. Kelly is purchasing docking stations with every new notebook. "As laptops become the primary machines at more and more companies, hot docking will be a big deal," added Rod Corder, vice president of engineering at New Media Corp., a PCMCIA card developer in Irvine, Calif. PNP was developed by Compaq, Intel Corp., and Phoenix Technologies Ltd., and more than 30 PC and card vendors are now building PNP-compliant products. But users will not see true PNP products until late this year when operating systems, including Microsoft's Chicago, are available with the technology built in, said developers. NEC Technologies Inc. recently demonstrated hot-docking capabilities with its Versa notebook and docking station, but that was only possible because of a beta version of Chicago that the machine was running. Until then, users will be required to load drivers for PC cards and notebooks upon installation. Intel offers hardware and software kits to developers that eliminate the need for users to have to set jumper switches. Despite efforts to enhance the docking station/notebook relationship, some users will remain true to portable adapters and PCMCIA cards for network connections. "The docking stations are fine but usually too expensive," said Chris Wendt, network administrator at EduServe Technologies Inc., a student-loan servicer in St. Paul. Minn. "But buy a pocket adapter and [users] can take it with them to a remote site, sit at a desk, and plug into the network." #### PCMCIA ExCA Another specification that's used in products today is ExCA, a subset of the general PCMCIA specification for card and socket services. ExCA applies to systems, rather than adapters, ensuring compatibility of PCMCIA sockets between compliant systems, according to PCMCIA officials. NEC's Versa 40E and 50E and Compaq's Concerto convertible notebooks, for example, are ExCA-compli- Work also continues in related areas of the PCMCIA group that will boost sup port of card and socket services. In fact BIOS developer SystemSoft Corp., of Natick, Mass., hopes to bring PNP and card and socket services closer together-a prospect that could mean even greater functionality for notebooks. "We're trying to make sure in our PNP BIOS efforts that the PCMCIA bus is treated properly and integrated into the PNP BIOS," said Paul Sereiko, director of product marketing at SystemSoft. "As the year progresses, and as PNP BIOS and PCMCIA become more integrated, there will be more robust offerings." COPYRIGHT ® 1993 ZIFF-DAVIS PUBLISHTNG COMPANY, L.P. ALL RIGHTS RESERVED #### **Emerging standards** Access.bus Main benefit: Ability to daisy-chain and "hot swap" up to 125 peripherals. #### **Supporting vendors** - ▶ Computer Access Technology Corp. Access.bus Station PC AT add-in card - ▶ Key Tronic Corp. WN101 keyboard and LifeTime mouse - Logitech Inc. **OEM** mouse #### ISA Plug and Play Main benefit: Ability to "hot dock" compliant notebooks into compliant docking stations. #### **Supporting vendors** - Compaq Computer Corp. Concerto notebook - ThinkPad notebook - NEC Technologies Inc. Versa 40E and 50E notebooks #### PCMCIA ExCA Main benefit: Assures PCMCIA socket compatibility between compliant systems. - Compaq Computer Corp. Concerto notebook - NEC Technologies Inc. Versa 40E and 50E notebooks This list is representative, not all-inclusive. #### For more information, contact: ACCESS.bus Industry Group 370 Altair Way, Suite 215 Sunnyvale, CA 94086 Tel: (408) 991-3517 Fax: (408) 991-3773 Computer Access Technology Corporation (CATC) 3375 Scott Blvd., Suite 410 Santa Clara, CA 95054 Tel: (408) 727-6600 Fax: (408) 727-6622 Microsoft Corporation One Microsoft Way Redmond, WA 98052-6399 Tel: (206) 936-5940 Fax: (206) 936-7329 #### Who's hopping on the ACCESS.bus? REPRINTED FROM WINDOWS SOURCES # APRIL 1994 # Undate SYSTEMS ROUNDTABLE # Who's Hopping on the ACCESS.bus? ACCESS.bus is an emerging technology that will (theoretically) support up to 125 low-speed serial I/O devices (mice, printers, scanners) daisy-chained from a single port. Similar in operation to the Apple Desktop Bus, the ACCESS.bus has the potential to eliminate the plethora of ports that clutter the back of PCs. ACCESS.bus was developed by Digital Equipment Corp. and Philips Semiconductors and is now controlled by the independent ACCESS.bus Industry Group. It shows signs of becoming an industry standard, and we asked key systems and peripherals vendors if, and where, ACCESS.bus fits into their plans. Some believe future monitors will be populated by ACCESS.bus ports for peripherals, while others think it has potential to shrink systems by reducing serial port slots. AST Research Corp., Acer America Corp., and Gateway 2000 declined to comment on ACCESS.bus technology, but several other vendors offered their opinions. Dell Computer Corp. won't be selling ACCESS.bus systems until the beginning of 1995 at the earliest. Distinguished engineer Jay Bell says the four-wire, telephone-style connector for the ACCESS.bus won't replace the serial bus: Future systems will have a serial port and the ACCESS.bus. He predicts that ACCESS.bus will take over but not in the first year. "I think it will take a couple of years for the peripherals to migrate over," says Bell. **AT&T Corp.** is a definite no-go for ACCESS.bus. Systems architect Tom Heil says that after analyzing ACCESS.bus more than a year ago: "We didn't see a need to partition a desktop environment. None April 1994 322 #### Who's hopping on the ACCESS.bus? ### Undate of our desktop systems would be partitioned that way." NEC Technologies' principal engineer Tom Schmidt foresees a day when monitors will conform to the proposed VESA Display Data Channel specification and support ACCESS.bus. "I think ACCESS.bus will become increasingly important because it allows a common channel for more than one device," says Schmidt. "The real attraction is that you can shrink the [PC] boxes by limiting the number of connections." Compaq Computer Corp.'s director of marketing Andrew Watson wouldn't comment on Compaq's ACCESS.bus plans, but said that "one of the problems with PCs is too many ports, and ACCESS.bus could solve that." He said that Compaq "will consider anything that will allow us to reduce the number of ports." IBM Personal Computer Co.'s David Bradley, manager of personal computing, is analyzing ACCESS bus technology and says you'll see it implemented in IBM's PC divisions when compatibility and cost issues are resolved. He says that the ACCESS bus peripherals "must be able to mimic current keyboard scan codes that older applications recognize, and it must not cost a great deal to implement." Logitech has an ACCESS bus mouse ready to ship, but hasn't sold one yet. "We don't have users asking for the bus, but we have one ready to be shipped to OEMs if they ask for it," says Denis Pavillard, Logitech's pointing device software manager. "We need a market to push it." He expects that Microsoft will be a trigger for ACCESS bus technology. Microsoft will support ACCESS.bus in Chicago (Windows 4.0) and the Plug and Play specification. Lexmark International, the printer manufacturer, showed a prototype ACCESS .bus keyboard at fall Comdex. Advisory engineer Jim Moses says, "It's a chicken or egg thing. You have to develop things to create a market. ACCESS will take a big step forward if computer companies integrate it into the motherboard and provide BIOS hooks." Digital Equipment Corp. pioneered ACCESS.bus in its DECstation 5000 Unix workstation but the company is waiting for PC vendors to introduce ACCESS bus systems before committing to the PC platform. Paul E. Nelson, DEC's senior engineer for input devices says, "I'd put it in, but management wants a market first." Nelson's ideal ACCESS. bus implementation: an ACCESS. bus keyboard with its own separate power supply, to interface with daisy-chained peripherals. -John McDonough COPYRIGHT © 1994 ZIFF-DAVIS PUBLISHING COMPANY L.P. . ALL RIGHTS RESERVED #### For more information, contact: ACCESS.bus Industry Group 370 Altair Way, Suite 215 Sunnyvale, CA 94086 (408) 991-3517 Computer Access Technology Corporation (CATC) 3375 Scott Boulevard, Suite 410 Santa Clara, CA 95054 (408) 727-6600 Philips Semiconductors 811 E. Arques Avenue P.O. Box 3409 Sunnyvale, CA 94088-3409 (408) 991-3518 ## ACCESS.bus revisited— ending the peripheral connection nightmare KEVIN GARDNER PHILIPS SEMICONDUCTORS # ACCESS.bus revisited—ending the peripheral connection nightmare deally, if you operate one of today's powerful nomadic PCs on the road, you should be able to plug into some kind of power supply pod or docking station upon return to your desktop. A portable would then assume the role of a standard desk-top computer, and you'd enjoy a full-sized keyboard, high-performance display, mouse and other accessories. The approach would provide performance equivalent to a standard desktop machine, but without the problems of disk swapping, file synchronization and duplication of expensive hardware. But what's the best way to accomplish this? On most portables, there isn't much room for connectors stout enough to reliably handle repeated insertions and withdrawals. What's more, on most desks there isn't much room for additional hardware and enclosures, and many nontechnical users don't want their desks entangled in a web of separable interconnects and bulky cables needed to connect peripherals. #### Simply serial Enter the updated ACCESS.bus, a network-on-a-desktop that conquers the limitations of peripheral connections. A single ACCESS.bus interface on a portable PC serially communicates with many peripherals over a single cable. Although initially introduced a few gars ago as a method of supporting about a dozen peripherals, today's ACCESS.bus can accommodate up to 125 peripherals. These can include fullsized keyboards, mice, bar-code readers, low-speed printers and even monitors and multi-dimensional pointing devices such as virtual reality gloves. Kevin Gardner is microcontroller product marketing manager, Philips Semiconductors (Sunnyvale, CA) Everyone can now take advantage of a single low-cost TTL serial interface operating at raw data rates to 100 kbits/s and higher. Significantly, an ACCESS.bus peripheral can be connected quickly and easily, without special procedures. No driver installation or device configuration is necessary. In fact, if you change a peripheral after you've powered-up, you don't need to reboot. You just plug in your peripheral and play. It's that simple. #### One size fits all Today, ACCESS bus, originally developed by Digital Equipment Corp and Philips Semiconductors, is offered as an open industry standard—free of fees or royalties. Indeed, an independent ACCESS.bus Industry Group (ABIG) now owns the bus specification and controls development of the protocols. ABIG currentboasts 55 members, including Intel, DEC, Fujitsu, Honeywell, IBM, Key Tronic, Lexmark, Logitech, Microsoft, Philips Semiconductors and Sun Microsystems ACCESS.bus is also supported by Microsoft in both MS-DOS and Windows, and by DEC VMS and Sun Solaris 2.x OSs. Several ABIG mem- bers also offer ACCESS.bus softwaredevelopment tools, including source code modules, cross assemblers, in-circuit emulators and EPROM programmers. Tailored compilers also assist C and PL/M codesmiths. Electrically, ACCESS.bus is based on the popular I<sup>2</sup>C (inter-integrated circuit) bus—an inexpensive two-wire serial implementation widely used to transfer data between 8051-family 8-bit microcontrollers in close proximity on circuit boards or within a system. These days, 1<sup>2</sup>C ports are included on many other microcontrollers and memories. Some UARTS, LCDs, I/O expanders, clock/calendars, and video and audio devices made by a variety of chip makers and peripheral manufacturers also include 1<sup>2</sup>C implementations. One of the strongest features of ACCESS.bus is its simplicity. Only four wires are required: a serial data line, a clock, power (+5 V) and ground. Cables and connectors are similar to RJ-style modular telephone cords, with the addition of shielding to meet FCC EMI/RFI guidelines. In operation, ACCESS.bus peripherals are typically daisy-chained on cable runs that extend up to 25 ft. For some applications, this distance can actually be interface configures each new device as it's plugged in, also polling the ACCESS.bus periodically to determine if any devices have been disconnected. On the host side, a typical ACCESS.bus interface is implemented with one microcontroller, two current source pull-ups, and an interface from the con- A single, dalsy-chained serial ACCESS.bus structure can support a variety of full-sized peripherals—especially keyboards and monitors. This typical configuration converts a powerful portable PC into a useful desktop adjunct. ### ACCESS.bus revisited— ending the peripheral connection nightmare #### SPOTIIGHT ON PORTABILITY troller to the host CPU. This compact configuration makes it easy to include the ACCESS,bus interface on virtually any portable computer's motherboard. #### **Unadorned device drivers** On each peripheral, a single ACCESS.bus microcontroller is also needed. As each device includes its own device-specific configuration information, however, it's easy to reconfigure a generic device driver so you don't have to code custom drivers. A generic pointing device driver, for example, could operate with a mouse, trackball, joystick, graphics tablet or data gloves. ACCESS.bus also supplies up to 1 A of current to power devices on the bus, although peripherals can also obtain power externally if desired. Each device connects to the bus' data and clock lines via open-collector or opendrain transistors, which are part of the ACCESS.bus hardware implemented in the controllers. In operation, all ACCESS.bus devices (host and any peripherals) are deemed bus masters when sending messages, and slaves when receiving messages; all messages on the bus are from one device to another, communicating in a halfduplex collision detection mode. If the host wishes to receive position data from a pointing device such as a mouse, it sends a message to the peripheral asking for that information. The peripheral responds with a separate message containing the requested information. #### The payoff ACCESS.bus delivers a simple means for connecting nearly unlimited numbers of peripherals without rebooting. Such simplicity has multiple payoffs: - OEMs only have to provide one ACCESS.bus port per portable computer. Unlike conventional multi-port approaches, no multiple UARTs are needed; - Plug-and-play peripherals can readily be connected to virtually any and all platforms, regardless of whether they are DOS-based PCs, Macintoshes or workstations; - Developers can create software that handles multiple cursors. This opens totally new application possibilities. For example, computer games could support multiple players that can join in or drop out at will; - Peripheral makers can get out of the specialized software driver business and concentrate on their core business, thereby saving development costs. They can also avoid authoring lengthy installation procedures and manuals: - Distributors and resellers can reduce inventories; only one version of each peripheral is needed. They'll also save time and manpower by not having to explain installation to oft-confused end-users: - Organizations will save on duplicate peripherals for people working on multiple systems. You could, for example, unplug a favorite mouse, trackball, digitizer or scanner, and plug it into another computer. For more information about the technologies, products or companies mentioned in this article, call or circle the appropriate number on the Reader Inquiry Card. ACCESS.bus Industry Group Sunnyvale, CA (408) 991-3517 Philips Semiconductors Sunnyvale, CA (408) 991-3518 ### State of the Art Reprinted with permission, from the August 1994 issue of BYTE Magazine © 1994 by McGraw-Hill, Inc., New York, NY. All rights reserved. # SERIOUSLY SERIAL The venerable RS-232 standard may be showing its age, but Access.bus and FireWire demonstrate that there is a lot of life left in serial technology #### MARK CLARKSON hose new gigabyte hard drives, flatscreen true-color monitors, quad-spin CD-ROM drives, and V.Fast modems are all very nice, and they add a lot of functionality to your computer system; however, the PC still has a long way to go in terms of letting you connect these devices quickly and easily to your computer. If you want proof, you need look no further than the rat's nest of cables that's coiled behind my computer—and probably behind yours, too. There must be a better way to hook all those fancy peripherals up to our computers. #### Yes, Seria It appears to many in the industry that most of the next generation of peripheral connections will be serial, transferring data 1 bit at a time rather than 8 or more bits in parallel. Why? Parallel communications require more wires to carry the signals. More wires means fatter, more expensive cables and wider, more expensive connectors with more pins to bend and break. Also, the more wires bundled together into a cable, the more electrical interference there is between signal wires, and the more thoroughly they have to be shielded. The more signals you deal with at the same time, the harder it is to keep them all in sync. And the faster and farther you try to push that signal, the worse the problems become. Add to this the fact that the size of computers continues to shrink. Some fit into a shirt pocket; they have little room for connectors today and will have less tomorrow. Yet even as computers become smaller in size, their power increases, and more than ever, people need to be able to hook them up in the real world. What they want then are small connectors and darned few of them. Serial links, with intrinsically fewer wires, require smaller connectors. AUGUST 1994 BYTE ### State of the Art Seriously Serial ## Pumping Up the Parallel Port #### An alternative to high-speed serial is sitting right in your PC he Centronics-style parallel port, says Larry Stein, president of Farpoint Systems (Jersey City, NJ), "became an industry standard the day IBM introduced the personal computer with a parallel port on it." At that time, a screamingly fast peripheral was a 240character-per-second dot-matrix printer, which received its data in ASCII. Today, you're more likely to be hooked up to an 8-page-per-minute laser printer, pumping down megabyte-size color graphics files. Yet if you own a newer PC, the parallel port on the back of it is identical in performance to the 1981 model whose speed tops out at around 150 KBps. Maintaining even that rate is processor-intensive-your CPU has to oversee moving data to and from the port, including all the handshaking between the computer and peripheral. The 150-KBps parallel port is woefully slow for many new printers, which can accept data at much higher speeds, as well as for other peripherals such as tape drives. It is inadequate for even the slowest of single-spin CD-ROM drives. It's obvious that the parallel port needs major pumping up if it's going to survive on the multimedia desktop. The IEEE 1284 standard defines a newer, faster, and better parallel port with some major muscle in it. The good news is that 1284 ports are backward-compatible with existing parallel ports; the Hewlett-Packard DeskJet will plug right in, using existing cable and connector. Even better news is that, for only the cost of a new cable, a 1284 parallel port can inject new life into your old printers. Current parallel connections are notoriously flaky at distances of more than 10 feet. "With 1284," says Stein, who is also chairman of the 1284 committee, "we wanted to go a minimum of 10 meters. It's important to realize that, in some cases, 1284 has the parallel port going 100 to 200 times faster than it was meant to originally. You can't do that using \$2 cables, so the 1284 standard defines the cable as well. Now we can guarantee that when a user buys a 1284 port, a 1284-capable product, and a 1284 cable, it'll work at 2 feet, 10 feet, or 30 IEEE 1284 actually defines four different modes for the new parallel port: nibble, byte, ECP (Enhanced Capabilities Port), and EPP (Enhanced Parallel Port). All modes have at least some bidirectional ability, allowing the printer to talk back to your computer. Data passing from the peripheral to the host is called back-channel communication. The first two modes, nibble and byte, provide for relatively slow back-channel communication, 4 and 8 bits at a time, respectively. ECP, intended mainly for host-to-printer connections, can achieve data rates of up to 4 MBps in both directions. The maximum speed depends on the peripheral and host computer. EPP allows you to attach devices such as CD-ROM and hard drives, which would normally plug into the internal bus, to the parallel port. In addition to high data speeds, EPP allows the system to regard the parallel port as an extension of the system bus. Although not as sophisticated as FireWire, EPP lets you hang multiple peripherals off a single port. All 1284-compliant devices can identify themselves and their capabilities to the host computer, letting the system know whether to speak in EPP, ECP, nibbles, or plain old Centronics. Microsoft has announced support for ECP- #### Get on the Serial Bus Ideally, people want to hook together lots of peripherals—and many different kinds of peripherals—with as little muss and fuss as possible. The way to do that, says Apple research scientist David James, is by using a bus: "People already know how to transfer data on buses, to and from a large number of devices. There's really no problem mapping a keyboard, a network, a disk, a storage device, or other things to a bus because everybody's been doing that for years." "But until the last few years," James continues, "people had always thought that buses had to be constrained to a back-plane—inside a chassis." A serial connection, however, extends the idea of a bus outside of the computer, to the desktop and beyond. Computers and peripherals simply read from and write to addresses on the serial bus. Those addresses represent other peripherals. These reads and writes can be interleaved, allowing multiple devices to communicate across the bus at the same time, so you can string a whole slew of peripherals off of a single port on a PC. James also points out that these transfers aren't restricted to those between the host computer and a peripheral: "They can go from one disk to another or from disk to printer, autonomously. The computer would tell the disk to start dumping data to some device, and then the disk would continue on its own, while your processor does something else. Sound good? A number of people think so. Two new serial-bus standards, Access.bus and P1394 (or FireWire), are hot candidates to become the primary peripheral ports on your desktop computer. #### Access bus Access.bus is a new standard intended to connect relatively low-speed devices such as keyboards, mice, modems, and printers. Originally conceived by DEC and Philips/Signetics and similar to the Apple Macintosh desktop bus, Access.bus is now being developed under the auspices of the ABIG (Access.bus Industry Group). Access, bus runs on a thin four-wire cable that resembles the one that currently connects the keyboard or mouse to your computer. Each end sports a single small connector that's a little bigger than an RJ-11 modular phone jack. Most Access, bus devices offer two sockets—in and out—to let devices be daisy chained together, similar to BYTE AUGUST 1994 compliant devices within Chicago, the next version of Windows. Chicago will use the ID string returned by ECP-compliant peripherals to automatically install the proper drivers. An EPP can even drive your existing printers much faster. Copy some graphics files to your plain-Jane, non-1284 printer today, comments Stein, and you'll get throughput ranging from 6 to 14 KBps. With an EPP port and a new 1284 cable, however, you could get as much as 500 KBps. "By the end of the year," Stein says, "you should see ECP printers capable of 400 KBps to 2 MBps." And the 1284 port has one thing going for it that none of the proposed serial standards do: an installed base of millions on millions on parallel-port-equipped devices, all of which will plug right in. But there's still a serious question about how well these new parallel ports will work when you add in all the extra baggage needed to allow them to compete with the new serial buses. To me, this technology stinks of death. The more I read about it and how much work goes into tweaking parallel ports to run 100 times faster than what was intended—with special cables, strict capacitance rules, and so on—the more convinced I am that the serial-port solutions are going to take over pretty quick. the way SCSI devices are interconnected. Access bus has a significant advantage restandard RS-232 serial connections. Today, for each and every serial peripheral, you need a separate port, interrupt, system address, and perhaps more. In theory, Access bus will let you run up to 125 peripherals—over a total cable distance of 8 meters—from a single jack in the back of your computer. "The beauty of Access bus," says David Rogers, manager of new business development for Computer Access Technology (Santa Clara, CA), "is that I'm using only one hex address, whether I've got one device on that port or 125." #### **Hot Plugs, Cold Boots** Every Access.bus peripheral, from laser printer to lowly mouse, is intelligent. Each contains a microcontroller that can identify the device to the bus and pass data along to the next peripheral in the chain. According to Rogers, Access.bus intelligence will improve your system's performance. "The messages passing over the Access.bus are off-loaded from your computer and CPU. The Access.bus host and the peripherals in the line are handling the passage of the messages, the bus arbitration, and so on. The system will actually run faster, because you don't have so many interrupts to the CPU." Where an RS-232 serial port interrupts the processor with every bit of information received, data moves along the Access.bus in the form of messages that are up to 127 bytes long, and each message generates only a single interrupt. This translates into far better system performance. But there's more. Access.bus also supports hot plugging. This means that you can disconnect peripherals and plug them in without having to power the computer down or reconfigure the system. There are no jumpers to set, no DIP switches to hrow, and no IRQs (interrupt requests) to reconfigure. Everything is automatic. When the system is first powered up, the Access.bus master inside your computer sends a message to every device on the bus. Each device responds with its ID number and a string that identifies what type of device it is—for example, a locator, keyboard, or text device—and gives any special capabilities and characteristics. The bus master assigns each peripheral an address on the serial bus and maintains a table of attached devices and their addresses. The individual peripherals watch the bus for reads or writes to their particular addresses and move data onto and off the bus accordingly. And whenever you pull a peripheral off the bus or plug in a new one, the Access bus master notices this and dynamically reconfigures the bus, requiring no user input at all. "For example," says Rogers, "we have a demo blackjack game for Windows, which uses Access bus drivers for multiple mouse input. I can hang six mice on my PC. Each has its own address, and each can only manipulate the chips and cards associated with it." he continues. "As I add or subtract players from the game, by adding and subtracting mice, the Access bus automatically reconfigures the system accordingly." #### Open Access Access.bus is an open standard that promoters hope will find a place on a variety of platforms, including PCs, Macs, and workstations. And the industry needs a new standard, especially in the fast-expanding arena of notebooks, subnotebooks, and PDAs (personal digital assistants)—smaller products with smaller connection space, where port real estate is at a real premium. Currently, users of such small computers who want to connect multiple peripherals must often suffer with proprietary interfaces and ungainly docking According to Rogers, "If a notebook manufacturer can add a small phone-jack-type port without having to add a proprietary connector, then it has opened up its product line to additional third-party solutions" Another limitation involves the number of access ports available. "Even on the desktop," Rogers notes, "where port economy is not as important, I'm still limited to four comm ports. If I want to go to a multiple RS-232 connection, I'm paying a premium, and I still have to worry about lower-level interrupts and DMA calls and older software that's unable to find the additional ports." A new specification for Super VGA monitors, called DDC2, calls for Access.bus to be incorporated into the monitor-to-PC connection. This will let you manipulate the front-panel controls—video mode, tint, brightness, and color—through software. In addition, manufacturers will be able to put Access.bus receptacles on the monitor, allowing you to plug your keyboard or mouse into your monitor, which will be more convenient than the standard back-of-the-computer location. How far away is Access.bus? Very close indeed, says Rogers. "Today, I can buy a host adapter, keyboards, trackballs, joysticks, mice, modems, and RS-232-to-Access.bus converters for older 232-based products. And I can operate under Windows 3.1, Windows NT, Solaris 2.3, and DOS. And if Chicago was shipping today, I could run under Chicago, too, because those drivers already exist." #### **How Fast Is Relatively Slow?** For all its advantages, Access.bus won't serve for every type of peripheral because it doesn't have enough bandwidth. Access.bus runs at speeds of up to 125 Kbps, which is not fast enough for multimedia applications involving high-quality audio and video or for hooking up hard drives. It is fast enough to run any device (e.g., mice, trackballs, joysticks, printers, keyboards, AUGUST 1994 BYTE ### **State of the Art** Seriously Serial "The marketplace clearly wants a connection to carry highperformance video and audio. It wants a connection that provides much higher bandwidth than has been required in the past and that connects to both PCs and consumer products. For the first time, we have a [P1394, or FireWire] cable that is being designed into both the computer and consumer worlds." **Bryan Rell** Texas Instruments and so on) that you might have attached to a serial port. "With Access.bus today," says Rogers, "I could have a 19.2-Kbps modem transmission in progress, be using my keyboard or my mouse, and have a bar-code scanner operating-all at the same time, on the same bus. If Access.bus isn't fast enough for you, then maybe it's time to step on up to FireWire. This new high-speed desktop serial bus, based on the ANSI draft standard P1394, is being developed jointly by Apple and Texas Instruments. FireWire also uses a flexible cable plus a nice, small connector inspired by the one used in the Nintendo Gameboy. You can reach behind your machine, without looking, and plug it in. FireWire offers many of the same advantages as Access.bus. You can daisy chain peripherals on a FireWire bus, hanging up to 63 devices off a single port. Up to 1022 FireWire buses can be bridged together, which should provide enough peripherals for anybody. As with Access.bus. FireWire provides hot plugging and automatic configuration. There's no need to set DIP switches or pull jumpers; you just plug in your cables and, as long as everything's connected correctly, everything works. (See the figure "P1394 Serial-Bus Physical Topology" on page 122.) But FireWire takes this concept to a whole new level. The goal is for each and every FireWire-compatible device on the planet to have its own unique 64-bit ID number. If you plug in a mouse (e.g., a Logitech three-button mouse), FireWire can identify it. It not only knows it's a Logitech threebutton mouse but also exactly which Logitech three-button mouse it is. If two identical mice are connected to the system, FireWire can tell which is which. For example, says Apple's James, "Say you had a disk drive with the unique identifier ABCD at location one. Then you move that disk, and the system finds that ABCD is now at location five. That's all right, because it just adjusts the operating-system tables accordingly. The unique identifier makes it very easy to find out where a peripheral has moved to." #### **How Far, How Fast?** Even if you use Access.bus, says James, "you still need another, faster bus for your disk. Well, why shouldn't you just use that faster bus for everything? The clear win is not in adding another connector to the computer but in eliminating one." Although it's significantly faster than Access.bus, FireWire is still strictly limited in the bandwidth it can deliver and the distance it can push a signal. It was, after all, designed for the desktop, and reasonable compromises had to be made to meet FireWire's low-cost objectives. According to James, "You certainly wouldn't want to run FireWire [over a cable length of | 50 meters." FireWire is no slouch. It operates at speeds ranging from 100 Mbps to 400 Mbps, which-protocols and overhead aside-should translate into 5 to 20 MBps of data actually humping across the wire from point A to point B. To drive data reliably at such high speeds, FireWire uses a technique called differential signaling. The cable contains two data lines (I'll call them A and B), and it uses both together to signal 1 bit of data. For a logical 1, A is high and B is low; for a logical 0, A is low and B is high. A FireWire cable also distributes power of from 8 to 40 VDC, at up to 1.5 amps. BYTE AUGUST 1994 ### **State of the Art** Seriously Serial FireWire's speed is not only fast enough for normal serial communications between mice, modems, and such; it's also fast enough to support real-time video and high-fidelity audio. FireWire supporters want to see it break out from the desktop and into the consumer electronics arena. They predict that FireWire ports will appear on camcorders, VCRs, and CD players. And if you can hook up camcorder and VCRs, why not just hook your camcorder to your VCR through your computer? Just think how easy that would make it to get video into your FireWireequipped, multimedia computer. "The marketplace clearly wants a connection to carry high-performance video and audio," says Bryan Bell, manager of computers and computer peripherals at Texas Instruments. It wants a connection that provides "much higher bandwidth than has been required in the past and that connects to both PCs and to consumer products. For the first time, we have a cable that is being designed into both the computer and the consumer worlds. It's really revolutionary." #### Will They Fly? Which of these serial standards is likely to catch on: Access.bus or FireWire? Maybe both? Or something like serial SCSI-3? Access.bus is basically a replacement for aging RS-232 technology, while FireWire has its sights set on new multimedia applications and consumer electronics. In addition, higher bandwidth comes at a price. Where Access.bus compliance might add 10 or 25 cents to the cost of a peripheral, FireWire will likely add about \$1 to \$10. Some pundits doubt Access.bus's usefulness as a printer connection. The communications needs of printers far exceed those of simple keyboards, mice, and modems. At 125 Kbps, Access.bus runs at only one-quarter the speed of today's Centronics-style parallel ports. PostScript documents that run 250 KB per page are not uncommon, even today, and that's just text with fancy fonts. Increasingly, printed documents are incorporating complex, computer-generated charts, drawings, and bit maps. As video and multimedia emerge as mainstream applications, we'll be seeing captured video stills, which will inflate document sizes even more. Adding color to this mix makes the problems more acute. At present, neither of these two standards has any installed base to speak of. "It's a Catch-22," says Apple's James. "It's hard to justify putting connectors on a motherboard before peripherals exist that connect to it." Still, the advantages of size, speed, and standardization are too great to be ignored. A trickle of serial-bus products is already appearing and should turn into a torrent by the middle of next year. "The idea of the serial bus," says James, "has allowed the bus to creep out of the box and onto the desktop. The interesting question then is how far will it creep? Will it just be to the desktop or will it eventually cover the whole building?" Mark Clarkson is a freelance science writer living in Wichita, Kansas. He can be reached on the Internet or BIX at mclarkson@bix.com. BYTE AUGUST 1994 #### **Philips Semiconductors** # **Section 6**Control Area Network (CAN) Bus Application Notes and Development Tools for 80C51 Microcontrollers #### CONTENTS | Control Area I | Network (CAN) overview | 335 | |----------------|----------------------------------------------------------------------------|-----| | 82C150 | CAN serial linked I/O device (SLIO) with digital and analog port functions | 336 | | 82C200 | Stand-alone CAN-controller | 365 | | PCA82C250 | CAN controller interface | 401 | #### **Control Area Network (CAN) overview** #### **CAN OVERVIEW** The Control Area Network (CAN) is a multiplexed wiring protocol developed by Bosch for use in automotive applications. As products supporting CAN have been made available by Philips Semiconductors and other semiconductor manufacturers, the protocol has become used in other industries including: industrial automation, machine tools, medical equipment, and building environmental control, to name a few. The CAN protocol is attractive for use in a wide range of applications because it has powerful error detection capabilities and features differential drive, and can be used comfortably in critical high noise environments. CAN is also very flexible in terms of the transmission media and the connection scheme, and is generally easy to adapt to most applications. Philips offers a wide range of parts that support the CAN protocol, including stand-alone parts as well as microcontrollers with integrated CAN interfaces. Datasheets for the 82C200 (Stand-alone CAN controller), 82C150 (CAN serial Linked I/O device), and 82C250 (CAN transceiver) are included in this section of this databook. Datasheets for the microcontrollers that have an integrated CAN interface (8XC592 and 8XC598) are included with Philips' 80C51 family products in Section 3 of this databook. March 1995 335 82C150 #### 1 FEATURES - · Single-chip I/O device with CAN protocol controller - Meets CAN protocol specification version 2.0 A and B (passive) with restricted bit timing - Fully integrated clock oscillator (no crystal required) - · 16 configurable digital or analog I/O port pins - Each of the port pins individually configurable via CAN-bus: port direction, port mode and event capture facilities for inputs (event driven or polling) - Up to sixteen digital inputs: automatic transmission of a CAN message on a change on inputs individually selectable - · Up to sixteen 3-state outputs - Up to two quasi-analog outputs with 10-bit accuracy - 10-bit analog-to-digital converter with up to six multiplexed analog input channels - · Two general purpose comparators - Bit rate from 20 kbit/s up to 125 kbit/s using internal oscillator - Automatic bit rate detection and calibration - Up to sixteen P82C150 nodes for one CAN-bus system - Four identifier bits programmable - SLIO functions controlled by a single intelligent node ("host") - · Sleep-mode with wake-up via CAN-bus - Differential CAN-bus input comparator and CAN-bus output driver - 5V ±4% supply voltage range - Operating temperature range from -40 to +125°C #### 2 GENERAL DESCRIPTION The P82C150 is a single-chip 16-bit I/O device including a Controller Area Network (CAN) protocol controller with automatic bit rate detection and calibration. It features 16 configurable I/O port pins with programmable direction, digital and analog modes. The P82C150 provides a configurable event capture facility supporting automatic transmission caused by a change on the port input pins. The clock oscillator requires no external components, thus, the cost of the CAN link is reduced significantly. The P82C150 is a very cost-effective way to increase the I/O capability of a microcontroller based CAN node as well as to reduce the amount and complexity of wiring. Advanced safety is provided by the CAN protocol. #### Applications: - Body electronics and instrumentation in automotive applications - Sensor/actuator interface in automotive and general industrial applications - Extension of I/O capabilities of microcontroller based CAN nodes #### 3 ORDERING INFORMATION | TYPE NUMBER | | PACKAGE | · · · · · · · · · · · · · · · · · · · | TEMPERATURE | |-------------|------|----------------------------------------------------|---------------------------------------|-------------| | | NAME | DESCRIPTION | VERSION | RANGE (°C) | | P82C150 AHT | SO28 | Plastic Small Outline; 28 leads; body width 7.5 mm | SOT136-1 | -40 to +125 | 82C150 #### 4 BLOCK AND FUNCTIONAL DIAGRAMS 82C150 82C150 #### 5 PINNING | SYMBOL | PIN | DESCRIPTION | |------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------| | P2 | 1 | I/O ports P2 to P3; Identifier programming input | | P3 | 2 | | | P4 | 3 | VO port 4; DPM2 output | | V <sub>SS1</sub> | 4 | Logic ground (0V; logic circuits and CAN-bus driver) | | P5 | 5 | I/O ports P5 to P6; analog input | | P6 | 6 | | | P7 | 7 | I/O port 7; analog input or A/D comparator 1 output | | V <sub>DD1</sub> | 8 | +5V supply voltage (logic circuits and CAN-bus driver) | | P8 | 9 | I/O port 8; analog input or comparator 3 output | | P9 | 10 | I/O port 9; analog input or comparator 2 output | | P10 | 11 | I/O port 10; comparator 3 inverting input or DPM1 output | | P11 | 12 | I/O port 11; comparator 3 non-inverting input | | P12 | 13 | I/O port 12; comparator 2 inverting input | | P13 | 14 | I/O port 13; comparator 2 non-inverting input | | P14 | 15 | I/O port 14; multiplexed analog signal | | P15 | 16 | I/O port 15; A/D comparator input | | P16 | 17 | Feedback output of A/D converter | | V <sub>DD2</sub> | 18 | +5V supply voltage (CAN input, oscillator, reference) | | REF | 19 | Reference voltage output (1/2 V <sub>DD2</sub> ) | | V <sub>SS2</sub> | 20 | Analog ground (0V; CAN input, oscillator, reference) | | RX0 | 21 | CAN-bus input | | RX1 | 22 | | | RST | 23 | External reset input (active-HIGH) for internal oscillator mode; pulled to +5V for external oscillator mode (see Section 10.3) | | XMOD | 24 | Connected to GND for internal oscillator mode; external reset input (active-LOW) for external oscillator mode (see Section 10.3) | | TX0 | 25 | Open-drain CAN-bus output: dominant = LOW; recessive = floating | | TX1 | 26 | Open-drain CAN-bus output: dominant = HIGH; recessive or at bus mode 2 floating | | P0/CLK | 27 | I/O port P0, Identifier programming input in internal oscillator mode; clock input in external oscillator mode (see Section 10.3) | | P1 | 28 | I/O port P1; identifier programming input | #### Note 1. In this documentation the port pins are referred to by their symbols, not by their pin number. For example P15 means I/O port 15 at pin 16 82C150 #### **6 FUNCTIONAL DESCRIPTION** #### 6.1 I/O functions The P82C150 provides 16 port pins (P15 to P0) which are individually configurable via CAN-bus. Besides the digital I/O functions some of these port pins provide analog I/O functions. #### Digital input functions: Input levels HIGH and LOW on the port pins (P15 to P0) can be read in two ways by the host node: - Polling: a Remote Frame is sent to the P82C150 to be answered by a Data Frame containing the Data Input Register contents. - Event capture: in case of edge-triggered mode, the P82C150 sends the same Data Frame caused by the event of a rising and/or falling edge on the corresponding port pins (see Table 2). #### Digital output functions: The Data Output Register is set via a CAN message. Its content is only output when the corresponding bits of the Output Enable Register are set to "1". #### Analog input/output functions: Up to six multiplexed analog input signals for A/D conversion or general purpose - Up to two quasi-analog output channels (DPM) - Two input comparators, for example for window comparator applications - A separate A/D input comparator with feedback output A/D converted digital results are obtained by reading the A/D register. Analog functions of each port pin are individually controlled by the Analog Configuration Register. Writing the I/O registers is done serially via CAN-bus by Data Frames. The first data byte contains the register address, and the second and third data bytes represent the register contents. If a read-only register is addressed, the contents of the second and third data bytes are ignored. It is recommended to set unused port pins to HIGH (100 $k\Omega$ resistor to $V_{DD}).$ #### 6.1.1 DATA INPUT REGISTER (ADDRESS 0; READ ONLY) This register contains the states of port pins P15 to P0 which are transmitted on request, or automatically by change of one of the input levels, provided that the respective input is configured to event capture mode (see Table 2). When an edge is detected the port state is loaded into the transmit buffer after the Control Field of the triggered message is sent. Thereby a delay for input settling is provided. If between edge detection and transmission of the data input register another input signal change at the input port occurs, the corresponding data input register bit is overwritten by the current input port value. Additionally the register content is sent automatically after wake up or bus mode change, once the bit time has been calibrated (part of the "sign-on" message). ### 6.1.2 POSITIVE EDGE REGISTER (ADDRESS 1; WRITE ONLY) This register contains configuration information per port pin for the event capture facility. The corresponding PE-bit (see Table 2) has to be set to "1" to enable capturing of the falling edge. ### 6.1.3 NEGATIVE EDGE REGISTER (ADDRESS 2; WRITE ONLY) This register contains configuration information per port pin for the event capture facility. The corresponding NE-bit (see Table 2) has to be set to "1" to enable capturing of the falling edge. The combination of PE and NE functions is possible. 82C150 Table 1 I/O Register map. | MSB | | | | - (1- | | | | | | | | | | | LSB | |-------------|---------------------------------|----------|-----------|--------------|------|-----|----------|-----|-----|-----|-----|-----|-----|----------|-----| | 15 | 14 | 13 | 12 | F | 9 | 6 | 8 | 7 | 9 | 2 | 4 | ဗ | 2 | - | 0 | | ADDRES | ADDRESS 0: DATA INPUT | INPUT | | | | | | | | | | | | | | | DI15 | DI14 | D113 | DI12 | DI11 | DI10 | DI9 | 80 | DI7 | 9IQ | DIS | DI4 | DI3 | DIS | 百 | 음 | | ADDRES | ADDRESS 1: POSITIVE EDGE | TIVE EDG | ш | 184.<br>184. | | | | | | | | | | | | | PE15 | PE14 | PE13 | PE12 | PE11 | PE10 | PE9 | PE8 | PE7 | PE6 | PE5 | PE4 | PE3 | PE2 | PE1 | PE0 | | ADDRES | ADDRESS 2: NEGATIVE EDGE | TIVE EDG | , i | | | | | | | | | | | | | | NE15 | NE14 | NE13 | NE12 | NE11 | NE10 | NE9 | NE8 | NE7 | NE6 | NE5 | NE4 | NE3 | NE2 | RET | NEO | | ADDRES | ADDRESS 3: DATA OUTPUT | OUTPUT | | | | | e weight | | | | | | | | | | DO15 | DO14 | DO13 | DO12 | 1100 | 0010 | 6OQ | 800 | 100 | 900 | DO5 | D04 | 603 | D02 | <u>8</u> | 8 | | ADDRES | ADDRESS 4: OUTPUT ENABLE | OT ENAB | ä | | | | | | | | | | - | | | | 0E15 | OE14 | OE13 | 0E12 | 0E11 | OE10 | OE9 | OE8 | OE7 | OE6 | OES | OE4 | OE3 | OE2 | OE1 | OE0 | | ADDRES | ADDRESS 5: ANALOG CONFIGURATION | OG CONF | -IGURATIO | z | | | | | | | | | | | | | ADC | SS3 | OC2 | 00 | 0 | M3 | M2 | M | SW3 | SW2 | SW1 | 0 | 0 | 0 | 0 | 0 | | ADDRES | ADDRESS 6: DPM1 | = | | | | | | | | | | | | | | | DP9 | DP8 | DP7 | DP6 | DP5 | DP4 | DP3 | DP2 | DP1 | DP0 | 0 | 0 | 0 | 0 | 0 | 0 | | ADDRES | ADDRESS 7: DPM2 | 12 | | | | | | | | | | | | | | | 6<br>0<br>0 | DQ8 | DQ7 | DQ6 | DQ5 | DQ4 | DQ3 | DØ5 | B | 000 | 0 | 0 | 0 | 0 | 0 | 0 | | ADDRES | ADDRESS 8: A/D | | | | | | | | | | | | | | | | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | AD0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | 82C150 **Table 2** Programming of the I/O registers to event capture on edge or to digital output (X = don't care). | REGISTER CON | | | DIGIT | TAL INPUT F | JNCTION | DIGITAL OUTPUT | |---------------|---------|---------|----------|--------------|--------------------|----------------| | PARTICULAR P | ORT PIN | Polling | Event Ca | pture on Edg | je | FUNCTION | | | Вітѕ | | RISING | FALLING | RISING AND FALLING | | | Positive edge | PE | X | 1 | 0 | 1 | X | | Negative edge | NE | X | 0 | 1 | 1 | - X | | Output enable | OE | Х | Х | X | X | 1 1 | ### 6.1.4 DATA OUTPUT REGISTER (ADDRESS 3; WRITE ONLY) This register contains the output data for the port pins. The output drivers are bitwise enabled by OE (see Section 6.1.5). New data for the output port register are processed and written to the output ports directly after the corresponding CAN message to the P82C150 is successfully checked and becomes valid. ### 6.1.5 OUTPUT ENABLE REGISTER (ADDRESS 4; WRITE ONLY) This register controls the output drivers of the port pins. The corresponding Output Enable Register bit has to be set to "1" to enable an output driver. If set to "0", the corresponding output driver is disabled (floating; see Fig.4). ### 6.1.6 ANALOG CONFIGURATION REGISTER (ADDRESS 5, READ/WRITE) This register contains the bits ADC, OC3 to OC1, M3 to M1 and SW3 to SW1 (see Fig.5). ADC bit (A/D conversion start bit; write-only bit): The P82C150 starts an A/D conversion cycle at ADC = 1 ended with the transmission of a message containing the result. After that, the ADC bit is reset automatically. OC3 to OC1 bits (comparator output data; read-only bits): The bits OC3 to OC1 represent the logical output level of the analog comparators at input port pins P10, P11, P12, P13 and P15. The P82C150 sends back the logical output value of these comparators after having received a Data Frame (see Section 6.2.3) addressing the Analog Configuration Register. The comparator outputs can be monitored at the output port pins P8, P9 and P7. M3 to M1 bits (multiplexer control bits; write-only bits): The logical value of the comparators is monitored on port pins P8, P9 and P7 (see Fig.4) by setting M3 to M1 to "1", provided that these pins are configured as outputs (OE = 1). Additionally the register content is sent automatically when the corresponding port bits in the Positive Edge Register and/or Negative Edge Register and the corresponding bits in the Output Enable Register are set (see Fig.4). SW3 to SW1 (analog switch control bits; write-only bits): One of the analog switches S1 to S6 can be closed by setting the switch bits to the corresponding value (see Fig.5). 82C150 | SW3 | SW2 | SW1 | | |-----|-----|-----|-----------------------| | 0 | 0 | 0 | no switch closed (S0) | | 0 | 0 | 1 | S1 closed | | 0 | 1 | 0 | S2 closed | | 0 | 1 | 1 | S3 closed | | 1 | 0 | 0 | S4 closed | | 1 | 0 | 1 | S5 closed | | 1 | 1 | 0 | S6 closed | | 1 | 1 | 1 | reserved | Evidently if P14 is driven, it may not be connected to any other driven pin via the internal analog switches (avoid short-circuit!). #### 6.1.7 DPM1 REGISTER (ADDRESS 6; WRITE ONLY) A quasi-analog output signal on port pin P10 is generated by distributed pulse modulation (DPM; see Fig.8) if the Output Enable bit is set (OE10 = 1). The DPM1 output signal is inverted by setting DO10 = 1. The number of output pulses during a DPM period is given by the DPM1 Register value. These pulses have 4 x t<sub>CLK</sub> length and are voltage is provided after smoothing the output signal by an external RC combination. #### 6.1.8 DPM2 REGISTER (ADDRESS 7; WRITE ONLY) The function of the DPM2 output (P4) and the DPM2 Register correspond to the definition of DPM1. #### 6.1.9 A/D REGISTER (ADDRESS 8; READ ONLY) This register contains the result of the A/D converted level of that I/O pin which was selected by the SW bits. The conversion is started by ADC-bit set to "1" (see Section 6.1.6), or by transmitting a Data Frame addressing the A/D Register. 82C150 #### 6.2 CAN functions The P82C150 meets the CAN protocol specification version 2.0 A and B (passive) with restricted bit timing because of the on-chip RC-oscillator and the automatic bitrate detection. In a system with P82C150 nodes there must be at least one conventional crystal-driven CAN controller (host node) which is compatible to the CAN specification V1.2 or later to control P82C150 nodes. Host nodes compatible to CAN specification V1.1 can also be used provided that the P82C150 nodes are powered by a high-accuracy power supply or they are in external oscillator mode (refer to section 10.3). Each time a P82C150 node receives a Data Frame, it initiates the transmission of a Data Frame containing four bits status information, the register address (previously received) and the current contents of the addressed register (exception: see Section 6.2.3). This enables the host node to verify that the addressed register has correctly been written in case of writable registers, and to read the contents in case of readable registers. 82C150 Table 3 Message types and format. | FRAME | TRANSMISSION BY<br>83C150 | RECEPTION AT 82C150 | |----------------|---------------------------|------------------------------------------------------------------------------------------| | Data Frame | yes (DLC = 3; DIR = 1) | yes (DLC = 3; DIR =0; calibration message with DLC = 2 to 8 allowed, see Section 6.2.10) | | Remote Frame | no | yes (DLC = 3; DIR = 1) | | Error Frame | yes | yes | | Overload Frame | yes (only as a response) | yes | #### Note 1. DLC = Data Length Code; DIR = LSB of Identifier (see Section 6.2.1). #### 6.2.1 CAN IDENTIFIER Data and Remote Frames to be processed by the P82C150 are of Standard Format with 11 Identifier bits ID.10 to ID.0. Frames with extended Identifier (CAN specification version 2.0 B) are ignored. #### 1 = recessive; 0 = dominant | ID.10 | | | 1 | IC | DENTIFIE | R | | | | ID.0 | 19. | |-------|---|----|---|----|----------|----|----|---|---|------|-----| | 0 | 1 | P3 | 1 | 0 | P2 | P1 | P0 | 1 | 0 | DIR | RTR | #### P3 to P0 Programmable identifier bits read from port pins P3 to P0 during reset. #### DIR "1" for transmission of Data Frames to the host. It must be set to "1" in Remote Frames and to "0" in Data Frames received from the host. #### RTR Remote Transmission Request bit. The input levels on P3 to P0, for example set by resistors to $V_{SS}$ to $V_{DD}$ , are latched in the Identifier latch with the falling edge of the RST input signal. They represent the variable part of the Identifier, while the remaining bits are fixed (mask-programmed), P3 to P0 can be used as I/O ports after reset. The way of identifier programming is based on two facts: - Each P82C150 operates with only two Identifiers at which the higher priority Identifier is used for Data Frame reception (there is an extra Identifier for calibration purposes). - There can be maximum sixteen P82C150 circuits in one network. #### 6.2.2 TRANSMISSION OF DATA FRAMES Data Frames transmitted by the P82C150 contain three data bytes (see Fig.6). The first data byte contains the status information and the register address A3 to A0, the other two data bytes contain the content of the addressed I/O Register. 82C150 Table 4 Data Frame Byte 1 | | STA | TUS | | | REGISTER | ADDRESS | | |------|-----|-----|-----|----|----------|---------|------------| | RSTD | EW | BM1 | BM0 | A3 | A2 | A1 | <b>A</b> 0 | | Status | | | | |-------------|----------------------------------------------|---------------------------------------------------|---------------------------------| | RSTD | It is "1" in the first message ("signated"). | ign-on" message) after the succe | ssful detection of the bit rate | | EW | "1", if the error warning limit (32 | 2) is reached. In the "sign-on" me | ssage RW is always "1". | | BM1 | Bus mode status bits. | en skriver en | | | ВМ0 | | | | | Register ad | ldress | | | | A3 | Register address bits. | | | | A2 | | | | | A1 | | | | | A0 | | | | The EW status bit is set when the Receive Error Counter or the Transmit Error Counter have exceeded the Error Warning Limit of 32, also temporarily, since the last successful transmission of a message. After each successful message transmission, the P82C150 delays the transmission of a possibly further pending message for three bit times. The reason is to give other CAN controllers - with a lower identifier priority - the possibility to transmit a message in case of faulty contact at one of the edge-triggered port pins. ### 6.2.3 RECEPTION OF DATA FRAMES AND REMOTE FRAMES Received Data Frames have the same format as transmitted ones, only the DIR-bit (ID.0) in the Arbitration Field is different. The status bits RSTD, EW, BM1 and BM0 are ignored during reception. The P82C150 confirms each reception of a Data Frame by transmitting a Data Frame containing the (new) contents of the addressed I/O Register. #### **Exceptions from the rule:** 1. Analog Configuration Register: If a P82C150 receives a Data Frame addressing the Analog Configuration Register and the ADC bit is set to "1", it will respond with two messages. The first message returns the contents of the Analog Configuration Register. The control instructions are executed (e.g. next analog input channel selected), and an A/D conversion cycle is started after a set-up time. After finishing the A/D conversion cycle, the second message is transmitted containing the result (A/D Register). #### 2. A/D Register: On receiving a Data Frame addressing the A/D Register, the P82C150 starts an A/D conversion cycle. It automatically returns the result of the conversion (A/D Register) by transmitting a respective Data Frame after finishing the A/D conversion cycle. At normal operation, the calibration messages are confirmed by returning a dominant bit in the acknowledge slot. There is no particular confirmation message returned by the P82C150. Only after entering the calibrated state (start-up), a Data Frame ("sign-on" message) containing the Data Input Register contents is transmitted indicating to the host node, that the P82C150 is now ready for transmission. #### Remote Frame: Received Remote Frames must have the Data Length Code DLC = 3 (Remote Frames with DLC ≠ 3 are ignored). It is answered by a Data Frame containing the contents of the Data Input Register. 82C150 #### 6.2.4 CAN-BUS MODES The P82C150 can pass through four CAN-bus modes under certain conditions (see Fig.7). In the bus modes 0 to 2 (see Table 5) the P82C150 is operating with different input comparator configurations. Bus mode 3 is the power reduced Sleep Mode. The bus modes support: - Communication on two balanced wires (differential system) - Communication on one wire in a two-wire differential system - Sleep Mode with wake-up via either a dominant signal on RX0 or RX1 input - Connection of a second transmission medium (redundancy) There are two possibilities for condition 1 to switch to the next mode (see Fig.7): - Overflow of the bit counter when 8192 is reached since the last calibration message - Overflow of the Transmit Error Counter (>255; bus-off limit reached). Table 5 Can-bus modes. | | BI | ΓS | RECEP | TION LEVEL | TRA | NSMISSION | |------------------|-----|-----|-------------------------------|-----------------------------------------|----------|-----------| | BUS MODE | BM1 | ВМ0 | Recessive | Dominant | TX1 | ТХ0 | | 0 = Differential | 0 | 0 | RX0 > RX1 | RX0 < RX1 | enabled | enabled | | 1 = One-wire RX1 | 0 | 1 | RX1 < REF | RX1 > REF | enabled | enabled | | 2 = One-wire RX0 | 1 | 0 | RX0 > REF | RX0 < REF | disabled | enabled | | 3 = Sleep | 1 | 1 | RX0 > REF<br>and<br>RX1 < REF | RX0 <ref<br>or<br/>RX1 &gt;REF</ref<br> | disabled | disabled | #### Note 1. Output TX1 is disabled in bus mode 2 to tolerate short-circuit between the CAN-bus wires CAN\_H and CAN\_L. 82C150 When the bus mode changes, all I/O Registers are cleared and outputs become floating (OE bits cleared). That means the I/O ports return to a fail-safe state whenever the P82C150 looses connection to its host controller. This is a kind of network watchdog function. The status bits are set to the following values after a bus mode change: - RSTD = 1 - EW = 0 - BM<sub>new</sub> = BM<sub>old</sub> + 1 The programmed Identifier bits remain unchanged. After reset the P82C150 changes directly into bus mode 3 (Sleep Mode). During Sleep Mode, the internal RX oscillator is stopped, and all the output drivers are disabled (I/O Register contents cleared). A P82C150 in Sleep Mode can be waken up via CAN-bus lines (dominant level on RX0 or RX1) or by a reset condition. #### 6.2.5 BIT TIMING The Nominal Bit Time of the P82C150 is subdivided into 10 Time Quanta. The Synchronization Time Segment (SYNC\_SEG) and the Propagation Time Segment (PROP\_SEG) are each one Time Quantum long. The Phase Buffer Segment 1 (PHASE\_SEG1) and the Phase Buffer Segment 2 (PHASE\_SEG2) are each four Time Quanta long. The Resynchronization Jump Width (SJW) is four Time Quanta long. The sample point is located at the end of the Phase Buffer Segment 1. The Nominal Bit Time is internally adjusted to that bit timing which is provided by the crystal driven host (calibration message). | | | | | 1 BIT | TIME | | | | | |------|------|-----|--------|--------|------|-----|-------|--------|------| | BT1 | BT2 | ВТ3 | BT4 | BT5 | ВТ6 | BT7 | ВТ8 | ВТ9 | BT10 | | SYNC | PROP | | DULAGE | - 0-01 | | | | | | | SEG | SEG | | PHASE | E-SEG1 | | | PHASE | E-SEG2 | | The usable bus length at a given bit rate is reduced in comparison to other CAN controllers with programmable bit timing because the Propagation Time Segment is fixed to $\frac{1}{10}$ length of the Nominal Bit Time. The bit segmentation of the crystal driven host should be programmed like the fixed bit segmentation of the P82C150, e.g. one bit time segment is $\frac{1}{10}$ length of the Nominal Bit Time (refer also to table 8 for bit time programming). 82C150 #### 6.2.6 CAN-BUS TRANSCEIVER The transceiver of the P82C150 consists of the configurable input comparator and of complementary open-drain driver outputs. The reference voltage REF is an additional output. #### CAN-bus input comparator (RX0, RX1): The input comparator monitors the transient voltage on RX1 and RX0. The result of the input comparator is "1" if the voltage levels of the CAN-bus lines are regarded as recessive, and "0" if they are regarded as dominant. The recessive state and the dominant state are not equivalent and may not be mixed-up. The input comparator is configurable depending on the four CAN-bus modes (see Table 5), supporting battery-powered applications (Sleep Mode) and tolerance against bus wiring failures. #### CAN-bus output drivers (TX0, TX1): The output driver function is shown in Table 6, The output driver TX1 is disabled in bus mode 2 to tolerate a short-circuit between the CAN-bus lines in a two-wire differential CAN physical layer. Table 6 CAN-bus driver output function. | CAN OUTPUT | RECESSIVE | DOMINANT<br>(MODES 0 AND 1) | DOMINANT<br>(MODE 2) | RESET STATE, BUS-OFF AND<br>SLEEP MODE (MODE 3) | |------------|-----------|-----------------------------|----------------------|-------------------------------------------------| | TX0 | floating | LOW | LOW | floating | | TX1 | floating | HIGH | floating | floating | #### 6.2.7 TRANSMIT AND RECEIVE LOGIC The transmit and receive logic stores the destuffed bit stream which was received or is about to be transmitted. The incoming Identifier is compared with that of the P82C150. The content of the message is transferred to the port logic in case of matching. At transmission, the message about to be sent is put together: the Identifier, the status information, the register address and the content of the addressed register from the port logic. ### 6.2.8 BIT STREAM PROCESSOR AND ERROR MANAGEMENT LOGIC The Bit Stream Processor (BSP) is a sequencer to control the data stream between the transmit/receive logic (parallel data) and the on-chip CAN transceiver (serial data). Reception/transmission, bit stuffing/destuffing, arbitration and error detection, according to CAN protocol specification version 2.0 A and B (passive), are performed. Further, automatic re-transmission of corrupted messages is handled by means of continuously comparing the output bit stream with the input bit stream. Moreover, the Bit Stream Processor provides control information to calibrate the internal bit time. The Error Management Logic is responsible for the complete CAN-inherent error management. #### 6.2.9 OSCILLATOR AND CALIBRATION The P82C150 contains an on-chip RC-oscillator. The bit time is automatically calibrated by messages being received via CAN-bus. During start-up (after wake-up or reset) any message is used to calibrate the bit time until the calibration is sufficient to receive messages correctly. From this time on, the bit time is calibrated and fine-tuned by calibration messages with a special Identifier transmitted by the crystal-operated host. Only P82C150 nodes being calibrated by calibration messages can transmit messages. The first message is transmitted directly after entering the calibrated state ("sign-on" message). Since the P82C150 is not able to transmit as long as the bit time is not calibrated, it cannot wake-up other CAN nodes via the bus line. Hence to keep the network alive, the calibration message must be transmitted regularly by a crystal-operated (host) node with a maximum repetition period of 8192 bit (bith length measured by the 82C150). It is recommended to select a repetition period between 3800 and maximum 8000 bit times. 82C150 Table 7 Example of a suitable calibration message. The two important 1/0 transitions are marked by underlines (1). | SOF | ARBITRATION FIELD | CONTROL<br>FIELD | DATA BYTE 1 | DATA BYTE 2 | CRC FIELD | |-----|-------------------|------------------|-------------------|-------------|----------------------| | 0 | 000 1010 1010 0 | 0001010 | <u>10</u> 10 1010 | 0000 0100 | 00010 1011 1000 0010 | #### Note #### I = stuff bit (recessive); (1) the total length is 67 bit from start-of-frame to end-of-intermission. #### 6.2.10 CALIBRATION MESSAGE The calibration message has to meet the following requirements - transmitted by a crystal-operated node (host node) - identifier: 000 1010 1010 (1 = recessive; 0 = dominant) - RTR bit: 0 - allowed control field: DLC = 2 to 8 - the first recessive to dominant transition after the control field must be followed by another recessive to dominant transition in a distance of exactly 32 bit (stuff bits included). Example of a suitable calibration message (there are others using different data bytes; see Table 7): · data length code: 0010 1st data byte: 1010 1010 (AAh)2nd data byte: 0000 0100 (04h) #### 6.3 Initialization #### 6.3.1 IDENTIFIER PROGRAMMING Most of the P82C150 identifier bits are fixed. Four bits are programmable via port pins P3 to P0. All output drivers are disabled at reset, also P3 to P0. Thus the outputs are floating unless the input level is defined by external components to define identifier bits. They are latched at the end of reset, and P3 to P0 can be used as port pins. It is not allowed, according to the CAN protocol specification, that multiple bus nodes transmit the same identifier bit combination. Therefore a P82C150 must have one of the 16 possible identifier bit combinations, one that is not yet occupied. #### 6.3.2 RESET FUNCTION RST = HIGH disables all output drivers P16 to P0, TX0 and TX1. All I/O Registers are automatically cleared and set to "0". The bit time is set greater than 50 $\mu$ s. #### After RESET: | status bits | identifier bits | |-------------|-----------------| | RSTD = 1 | ID.8 equals P3 | | EW = 1 | ID.5 equals P2 | | BM1 = 0 | ID.4 equals P1 | | BM0 = 0 | ID.3 equals P0 | If a particular clock period is necessary, e.g. for a dedicated DPM output frequency, this can be achieved by feeding an external clock signal into P0. RST and TEST must be permanently HIGH for this special mode. A reset is then performed as usual (RST = HIGH; TEST = LOW). #### 6.3.3 BIT TIME CALIBRATION The P82C150 must receive at least three messages to calibrate its bit time after reset or change of bus mode. The first message is used to detect the bit time length (rough calibration) between two consecutive falling edges at the output of the CAN input comparator. Therefore the bit stream should contain a sequence of "1010". After rough calibration the P82C150 can receive any valid CAN message correctly and executes respective commands without giving an acknowledge. With another valid CAN message and additionally with one valid calibration message the P82C150 is fully calibrated and sends its "sign-on" message. As long as the P82C150 is fully calibrated the P82C150 acts as an active CAN node. The P82C150 treats any CAN message (including the calibration message) as a valid message, when these messages are terminated by an error passive frame because of a missing acknowledge. This situation may occur whenever a host node works together with P82C150's and the host node doesn't receive an acknowledge as long as the P82C150's are not fully calibrated. 82C150 #### Sign-on message: This special Data Frame is transmitted once by the P82C150 after entering the calibrated state. It indicates to the host node that the P82C150 is ready for transmission. The sign-on message returns the contents of the Data Input Register, and can be recognized by the host mode by checking the RSTD status bit. Sign-on message RSTD =1; other Data Frames RSTD = 0. Note that in the sign-on message the EW bit is "1". Nevertheless the P82C150 status with the error counters are set to "0". 82C150 #### 6.4 P82C150 operation after RESET or change of bus mode The following diagram describes the calibration procedure of the P82C150 after power on reset or after a bus mode change. 82C150 #### 7 LIMITING VALUES In accordance with the Absolute Maximum Rating System (IEC 134). | SYMBOL | PARAMETER | MIN. | MAX. | UNIT | |--------------------|-------------------------------------------------------------------------------------|------|----------------------|------| | $V_{DD}$ | supply voltage on V <sub>DD</sub> pin | -0.5 | +6.5 | V | | VI | DC input voltage on any pin<br>(RX0, RX1, TX0, TX1 excluded) | -0.5 | V <sub>DD</sub> +0.5 | V | | I <sub>I</sub> | RX1 and RX0 input current | - ' | ±2 | mA | | I <sub>REF</sub> | reference output current | - | ±2 | mA | | lo | port output current at port enabled (pins P0 to P15) | _ | ±5 | mA | | | port output current at analog switch enabled (OE-bits = 0; pins P5 to P9, P13, P14) | _ | 7.5 | mA | | | TX0 and TX1 output current | - | 30 | mA | | P <sub>O tot</sub> | total power dissipation (port outputs together) | | 200 | mW | | T <sub>amb</sub> | operating ambient temperature range: | -40 | +125 | °C | | T <sub>stg</sub> | storage temperature range | -65 | +150 | °C | | P <sub>tot</sub> | total power dissipation | | 1 | W | 82C150 #### **8 DC CHARACTERISTICS** $V_{DD}$ = 5 V $\pm$ 4%; $V_{SS}$ = 0 V and $T_{amb}$ = -40 to +125°C unless otherwise specified. | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |-------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|---------------------------|----------| | Supply | | | | | 1 | | V <sub>DD</sub> | supply voltage range | | 4.8 | 5.2 | V | | I <sub>DD</sub> | supply current | $V_{RST} = V_{DD}$ ; all port inputs connected via 1 M $\Omega$ to GND | | 22 | mA | | I <sub>SM</sub> | sleep mode current | Ports P15, P13 and P11 connected to $V_{DD}$ ; Ports P12 and P10 connected to $V_{SS}$ ; all other port inputs connected via 1 M $\Omega$ to GND | | 1 | mA | | CAN Inp | ut comparators RX0 and RX1 | 1.5V < V <sub>I</sub> < (V <sub>DD2</sub> - 1.5V) | Tax Tax Sign | <del> </del> | | | V <sub>DIF</sub> | differential input voltage | note 1 | ±25 | T | mV | | V <sub>HYST</sub> | input voltage hysteresis | note 1 | 8 | 30 | mV | | l <sub>l</sub> | input current | 0.45 < V <sub>I</sub> < V <sub>DD</sub> - 0.45 | | ±400 | nA | | CAN out | out driver TX0 and TX1 | port pins P0 to P16 unloaded | <del></del> | · · | | | V <sub>OLT</sub> | TX0 output voltage low; note 3 | I <sub>OLT</sub> = 1.5 mA<br>I <sub>OLT</sub> = 10 mA | _ | 0.1 | V | | V <sub>OHT</sub> | TX1 output voltage high; note 4 | I <sub>OHT</sub> = -1.5 mA<br>I <sub>OHT</sub> = -10 mA | V <sub>DD</sub> -0.1<br>V <sub>DD</sub> -1 | _ | V | | Referenc | e voltage REF | | | | - | | $V_{REF}$ | reference output voltage | $I_0 < \pm 75 \mu A$ | 0.5V <sub>DD2</sub> -0.25 | 0.5V <sub>DD2</sub> +0.25 | V | | Control i | nputs RST, XMOD and digital por | t inputs P0/CLK, P1 to P15 | - | | <u> </u> | | $V_{IL}$ | input voltage LOW | | _ | 0.2V <sub>DD</sub> | V | | $V_{IH}$ | input voltage HIGH | | 0.7V <sub>DD</sub> | _ | V | | $V_{HYST}$ | input voltage hysteresis | note 1 | 0.5 | _ | V | | l <sub>IL1</sub> | input leakage current | $0.45 < V_I < V_{DD} - 0.45$ | | ±10 | μА | | Digital po | ort outputs P0/CLK, P1 to P16 | OE bits set | | | | | V <sub>OL</sub> | output voltage LOW | I <sub>OL</sub> = 4mA (sink) | _ | 1 | V | | V <sub>OH</sub> | output voltage HIGH | I <sub>OH</sub> = -4mA (source) | V <sub>DD</sub> -1 | _ | v | | | parator P12, P13 and OC3<br>for P10, P11 | 1.5V < V <sub>I</sub> < (V <sub>DD2</sub> - 1.5V) | | | 1 * | | V <sub>DIF1</sub> | differential input voltage | note 1 | ±10 | T | mV | February 1995 354 82C150 | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |------------------|---------------------------|----------------------------------------------------|--------------------------|--------------------------|------| | OC1 com | parator input P15 | 1.5 V < V <sub>I</sub> < (V <sub>DD2</sub> -1.5 V) | | | | | Visw | input switch-over voltage | note 1 | | | | | | lower threshold | | 0.5V <sub>DD</sub> -0.01 | | V | | | upper threshold | | | 0.5V <sub>DD</sub> +0.01 | V | | I <sub>LI2</sub> | input leakage current | 0.45 < V <sub>I</sub> < V <sub>DD</sub> - 0.45 | T- | ±400 | nA | | C <sub>IA</sub> | analog input capacitance | note 1 | <u> </u> | 20 | pF | | Analog sv | vitches | $I_{ON} = \pm 4 \text{ mA}$ | | | | | R <sub>ON</sub> | On resistance | between P5 to P9, P13 and<br>P14; note 1 | 20 | 200 | Ω | #### Notes to the "DC characteristics" - 1. These values are characterized but not 100% production tested. - Alteration of V<sub>DD</sub> between two calibration messages should not exceed 0.2V to avoid failures during CAN message transfer. If CAN devices according to CAN specification V1.0 or V1.1 (like the 82C200 V0 or V1) are in the same network with the 82C150, then this alteration of V<sub>DD</sub> should be limited to 0.1V for the 82C150. - 3. The TX0 output pin is an open drain pull-down driver (no pull-up driver included). - 4. The TX1 output pin is an open drain pull-up driver (no pull-down driver included). 82C150 #### 9 AC CHARACTERISTICS $V_{DD}$ = 5 V $\pm$ 4%; $V_{SS}$ = 0V; $C_L$ = 100 pF (output pins); $T_{amb}$ = -40 to +125°C; unless otherwise specified. | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |----------------------|------------------------------------------------------------------|------------------------------------------------------------------|----------------|------------------|------| | f <sub>CLK_INT</sub> | system clock frequency on-chip | internal oscillator | 4 | 10 | MHz | | t <sub>bit</sub> | bit time on CAN-bus | note 2 | 8 | 50 | μs | | t <sub>RST1</sub> | min. RST pulse width after power on | note 1 | 10 | | ms | | t <sub>RST2</sub> | min. RST pulse width during operation | note 1 | 1 | | μs | | t <sub>hold</sub> | ID hold time after end of reset | note 1 | | 100 | ns | | t <sub>d</sub> | total signal delay of CAN input comparator and CAN output driver | 1.5 V < $V_I$ < ( $V_{DD}$ -1.5 V);<br>$V_{DIF}$ = ±25mV; note 1 | - | 60 | ns | | t <sub>rep</sub> | max. time without recalibration message | | - 4474 74 | 8000 | bit | | A/D comp | arator input P15 | | | 1. | | | t <sub>cyc</sub> | A/D conversion cycle time | | 0.4 | T <sub>1.1</sub> | ms | | t <sub>init</sub> | initialization time of A/D conversion | | 0.4 | 2.1 | ms | | OC2 comp | parator P12, P13 and OC3 comparato | or P10, P11 | | | | | t <sub>resp</sub> | response time | V <sub>DIF1</sub> = ±100 mV, note 1 | <del>- [</del> | 1 | μs | | DPM1 and | DPM2 outputs | | | | 1' | | t <sub>DPM</sub> | repetition time of DPM cycle | | 0.4 | 1.1 | ms | #### Notes to the AC characteristics: - 1. These values are characterized but not 100% production tested. - 2. Other bit time values are possible with the external oscillator mode (refer to chapter 9.3). 82C150 #### 10 APPLICATION INFORMATION #### 10.1 Maximum bus length The bit timing parameters refer to using a P8xCE598 or P8xC592 microcontroller with on-chip CAN interface as a host node (see Fig.21). #### Assumptions - the total in/out delay of external transceiver circuit is 170 ns (e.g. PCA82C250 CAN transceiver; (see Fig.20). - the propagation delay on the transmission medium is 5.5 ns/m. Table 8 Maximum bus length for CAN-bus systems with P82C150 nodes. | BIT RATE | | INDICATION | BIT TIMING (P8XCE598/P8XC592) | | | | |----------|----------------------------|---------------------------|-------------------------------|---------------|---------------|--| | (kbit/s) | t <sub>prop</sub> (note 1) | FOR MAXIMUM<br>BUS LENGTH | f <sub>CLK</sub> (MHz) | BTR0 (note 2) | BTR1 (note 2) | | | 125 | 0.8 μs | 15 m | 15 | C5 h | 34 h | | | 100 | 1 μs | 35 m | 16 | C7 h | 34 h | | | 50 | 2 μs | 120 m | 16 | CE h | 34 h | | | 20 | 5 μs | 400 m | 16 | E7 h | 34 h | | #### **Notes** - t<sub>prop</sub> is the maximum propagation delay between two CAN-bus nodes (delays of on- and off-chip transceiver circuits included) - 2. BTR0 and BTR1 (hex values) are particular configuration registers referring to bit timing. #### 10.2 Start up sequence The following start-up sequence (Fig.11 and Fig.12) shows a simple example how P82C150 nodes can be controlled from a host node. This application example works with different system configurations: - One conventional crystal-driven CAN node and one or more P82C150 nodes - More than one conventional crystal-driven CAN node and one or more P82C150 nodes 82C150 February 1995 358 82C150 #### 10.3 External oscillator mode In this mode the P82C150 operates with an external clock instead with the on-chip RC-oscillator. The following figure shows the application with an external clock: In this mode the P82C150 can achieve bit rates below 20 kbit/s and above 125 kbit/s. The DPM pulse width is 4 x $t_{CLK}$ of the external clock. The corresponding CAN identifier bit at port P0 is set to the value 0. Therefore only eight P82C150 based CAN nodes operate within the same network in external oscillator mode Note that this mode is not the normal operation mode. #### 10.4 Using digital I/O port functions The following figure shows the principle application for digital input and output. 82C150 ## 10.5 Using DPM The most simple way to generate an analog voltage using the P82C150 is to apply an external low pass filter at one of the DPM (Distributed Pulse Modulation) outputs. The most simple implementation concept is a RC-filter of first order (refer to Fig.16). Regarding the selection of the time constant (edge frequency) of this filter, a trade-off between minimizing of the rip<sub>ple</sub> voltage for maximum accuracy and minimum of the settling time has to be considered. #### Note: If the output is loaded by a resistive load, this will decrease the accuracy due to the voltage drop across the series resistor. In these cases a low value for the series resistor should be chosen. The repetition time of one DPM cycle can be derived from: $$t_{CYC} = \frac{4096}{f_{OSC}}$$ # CAN serial linked I/O device (SLIO) with digital and analog port functions 82C150 ## 10.6 Using ADC The application in Fig.18 can be used for analog to digital conversion for only one analog input signal. With the values R1 = R2 = 100 k $\Omega$ and C = 3.3 nF the implemented ADC can achieve an accuracy of 8 bit. The external components should be connected close to the port pins P15 and P16 with short wiring to avoid disturbances at the analog input port pin P15. Using the on-chip multiplex function the P82C150 provides up to six input port pins to convert analog input signals to digital values (see Fig.19). The period for one ADC cycle is identical to the length of one DPM cycle. # CAN serial linked I/O device (SLIO) with digital and analog port functions 82C150 #### 10.7 Using analog input port functions The following figure shows the wide range of analog input applications: - · comparison of two analog input signals - comparison of one analog input signal against a fixed threshold - window comparator including monitoring the comparator outputs at the port pins P8 and P9; additional automatically generated messages, when the corresponding port bits in the negative and/or positive edge register are set - · local control two-step system. February 1995 82C150 # CAN serial linked I/O device (SLIO) with digital and analog port functions 82C150 ## 10.8 CAN-bus system applications 82C200 #### 1 FEATURES - · Multi-master architecture - · Interfaces with a large variety of microcontrollers - Bus access priority (determined by the message identifier) - · 2032 message identifiers - Guaranteed latency time for high priority messages - Powerful error handling capability - Data length from 0 to 8 bytes - Configurable bus interface - · Programmable clock output - Multicast and Broadcast message facility - Non destructive bit-wise arbitration - Non-return-to-zero (NRZ) coding/decoding with bit-stuffing - Programmable transfer rate (up to 1 Mbit/s) - Programmable output driver configuration - Suitable for use in a wide range of networks including the SAE networks Class A, B and C - 16 MHz clock frequency - 40 to +85/125 °C operating temperature. #### 2 GENERAL DESCRIPTION The PCA82C200; PCF82C200 (hereafter generically referred to as PCX82C200) is a highly integrated stand-alone controller for the controller area network (CAN) used within automotive and general industrial environments. The temperature range includes an automotive temperature range version (PCA82C200) of –40 to +125 °C and a –40 to +85 °C version (PCF82C200) for general applications. The PCX82C200 contains all necessary features required to implement a high performance communication protocol. The PCX82C200 with a simple bus line connection performs all the functions of the physical and data-link layers. The application layer of an Electronic Control Unit (ECU) is provided by a microcontroller, to which the PCX82C200 provides a versatile interface. The use of the PCX82C200 in an automotive or general industrial environment, results in a reduced wiring harness and an enhanced diagnostic and supervisory capability. #### 3 ORDERING AND PACKAGE INFORMATION | PHILIPS | TOHILDS NORTH AMERICA | | PAC | TEMPERATURE | | | | |-----------------------------------|--------------------------------|------|--------------|-------------|---------|-------------|--| | PART ORDER NUMBER<br>PART MARKING | PART ORDER NUMBER <sup>1</sup> | PINS | PIN POSITION | MATERIAL | CODE | RANGE (°C) | | | PCA82C200P | PCA82C200PN | 28 | DIL | plastic | SOT117 | -40 to +125 | | | PCA82C200T | PCA82C200TD | 28 | SO28 | plastic | SOT136A | -40 to +125 | | | PCF82C200P | PCF82C200PN | 28 | DIL | plastic | SOT117 | -40 to +85 | | | PCF82C200T | PCF82C200TD | 28 | SO28 | plastic | SOT136A | -40 to +85 | | #### NOTE: November 1992 365 <sup>1.</sup> Parts ordered by the Philips North America part number will be marked with the Philips part marking. 82C200 82C200 ## 4 PINNING 82C200 ## Pinning description | SYMBOL | PIN | DESCRIPTION | |-------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AD7-AD0 | 2, 1, 28–23 | Multiplexed address/data bus. | | ALE | 3 | ALE signal (Intel mode) or AS input signal (Motorola mode). | | CS | 4 | Chip select input, LOW level allows access to the PCX82C200. | | RD | 5 | RD signal (Intel mode) or E enable signal (Motorola mode) from the microcontroller. | | WR | 6 | WR signal (Intel mode) or RD/WR signal (Motorola mode) from the microcontroller. | | CLK OUT | 7 | Clock output signal produced by the PCX82C200 for the microcontroller. The clock signal is derived from the built-in oscillator, via the programmable divider (see section 6.5). This output is capable of driving one CMOS or NMOS load. | | V <sub>SS1</sub> | 8 | Ground potential for the logic circuits. | | XTAL1<br>(note 1) | 9 | Input to the oscillator's amplifier. External oscillator signal is input via this pin. | | XTAL2<br>(note 1) | 10 | Output from the oscillator's amplifier. Output must be left open when an external oscillator signal is used. | | MODE | 11 | Mode select input: connected to $V_{\text{DD}}$ selects Intel mode; connected to $V_{\text{SS}}$ selects Motorola mode. | | V <sub>DD3</sub> | 12 | 5 V power supply for the output driver. | | TX0 | 13 | Output from the output-driver 0 to the physical bus-line. | | TX1 | 14 | Output from the output-driver 1 to the physical bus-line. | | V <sub>SS3</sub> | 15 | Ground potential for the output driver. | | INT | 16 | Interrupt output, used to interrupt the microcontroller (see section 6.2.4). INT is active if the Interrupt Register contains a logic HIGH bit (present). INT is an open drain output and is designed to be a wired-OR with other INT outputs within the system. A LOW level on this pin will reactivate the IC from the sleep mode (see section 6.2.2). | | RST | 17 | Reset input, used to reset the <u>CAN</u> interface (LOW level). Automatic power-ON reset can be obtained by connecting $\overline{RST}$ via a capacitor to $V_{SS}$ and via a resistor to $V_{DD}$ (e.g. $C=1~\mu F;~R=50~k\Omega$ ). | | $V_{DD2}$ | 18 | 5 V power supply for the input comparator. | | RX0-RX1 | 19, 20 | Input from the physical bus-line to the input comparator of the PCX82C200. A dominant level will wake-up the PCX82C200. A recessive level is read if RX0 is higher than RX1 and vice versa for the dominant level. | | V <sub>SS2</sub> | 21 | Ground potential for the input comparator. | | V <sub>DD1</sub> | 22 | 5 V power supply for the logic circuits. | 368 #### Note 1. XTAL1 and XTAL2 pins should be connected to $\rm V_{SS}$ via 15 pF capacitors. November 1992 82C200 #### **5 FUNCTIONAL DESCRIPTION** The PCX82C200 contains all necessary hardware for a high performance serial network communication (see Fig.1). The PCX82C200 controls the communication flow through the area network using the CAN-protocol. The PCX82C200 meets the following automotive requirements: - · short message length - · guaranteed latency time for urgent messages - bus access priority, determined by the message identifier - · powerful error handling capability - configuration flexibility to allow area network expansion. The latency time defines the period between the initiation (Transmission Request) and the start of the transmission on the bus. Latency time is dependent on a variety of bus related conditions. In the case of a message being transmitted on the bus and one distortion the latency time can be up to 149 bit times (worst case). For more information see section 7. #### 5.1 Interface Management Logic (IML) The IML interprets commands from the microcontroller, allocates the message buffers (TBF, RBF0 and RBF1) and provides interrupts and status information to the microcontroller. #### 5.2 Transmit Buffer (TBF) The TBF is a 10 byte memory into which the microcontroller writes messages which are to be transmitted over the CAN network. ## 5.3 Receive Buffers (RBF0 AND RBF1) The RBF0 and RBF1 are each 10 byte memories which are alternatively used to store messages received from the CAN network. The CPU can process one message while another is being received. #### 5.4 Bit Stream Processor (BSP) The BSP is a sequencer, controlling the data stream between the Transmit Buffer, the Receive Buffer (parallel data) and the CAN-bus (serial data). #### 5.5 Bit Timing Logic (BTL) The BTL synchronizes the PCX82C200 to the bitstream on the CAN-bus. #### 5.6 Transceiver Control Logic (TCL) The TCL controls the output driver. #### 5.7 Error Management Logic (EML) The EML performs the error confinement according to the CAN-protocol. #### 5.8 Controller Interface Logic (CIL) The CIL is the interface to the external microcontroller. The PCX82C200 can directly interface with a variety of microcontrollers. # 6 CONTROL SEGMENT AND MESSAGE BUFFER DESCRIPTION The PCX82C200 appears to a microcontroller as a memory-mapped I/O device due to the on-chip RAM, guaranteeing the independent operation of both devices. #### 6.1 Address allocation The address area of the PCX82C200 consists of the Control Segment and the message buffers. The Control Segment is programmed during an initialization download in order to configure communication parameters (e.g. bit timing). Communication over the CAN-bus is also controlled via this segment by the CPU. During initialization the CLOCK OUT signal may be programmed to a value determined by the microcontroller (see Fig.1). A message which is to be transmitted, must be written to the Transmit Buffer. After a successful reception the microcontroller may read the message from the Receive Buffer and then release it for further use. #### 6.2 Control Segment layout The exchange of status, control and command signals between the microcontroller and the PCX82C200 is performed in the control segment. The layout of this segment is shown in Fig.3. After an initial down-load, the contents of the registers Acceptance Code, Acceptance Mask, Bus Timing Registers 0 and 1, and Output Control should not be changed. These registers may only be accessed when the Reset Request bit in the Control Register, is set HIGH (see section 6.2.1). 82C200 370 November 1992 82C200 Table 1 Register map | TITLE | ADDR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------------------|----------|---------------|-----------------|-----------------------------|----------------------------------|-----------------------------------------|---------------------------------|--------------------------------|------------------------------| | Control Seg | ment | | | | | | | | | | Control<br>Register | 0 | Test<br>Mode | Sync | reserved | Overrun<br>Interrupt<br>Enable | Error<br>Interrupt<br>Enable | Transmit<br>Interrupt<br>Enable | Receive<br>Interrupt<br>Enable | Reset<br>Request | | Command<br>Register | 1 | reserved | reserved | reserved | Goto<br>Sleep | Clear<br>Overrun<br>Status | Release<br>Receive<br>Buffer | Abort<br>Trans-<br>mission | Trans-<br>mission<br>Request | | Status<br>Register | 2 | Bus<br>Status | Error<br>Status | Transmit<br>Status | Receive<br>Status | Trans-<br>mission<br>Complete<br>Status | Transmit<br>Buffer<br>Access | Data<br>Overrun | Receive<br>Buffer Stat | | Interrupt<br>Register | 3 | reserved | reserved | reserved | Wake-Up<br>Interrupt | Overrun<br>Interrupt | Error<br>Interrupt | Transmit<br>Interrupt | Receive<br>Interrupt | | Acceptance<br>Code<br>Register | 4 | AC.7 | AC.6 | AC.5 | AC.4 | AC.3 | AC.2 | AC.1 | AC.0 | | Acceptance<br>Mask<br>Register | 5 | AM.7 | AM.6 | AM.5 | AM.4 | AM.3 | AM.2 | AM.1 | AM.0 | | Bus Timing<br>Register 0 | 6 | SJW.1 | SJW.0 | BRP.5 | BRP.4 | BRP.3 | BRP.2 | BRP.1 | BRP.0 | | Bus Timing<br>Register 1 | 7 | SAM | TSEG2.2 | TSEG2.1 | TSEG2.0 | TSEG1.3 | TSEG1.2 | TSEG1.1 | TSEG1.0 | | Output<br>Control<br>Register | 8 | OCTP1 | OCTN1 | OCPOL1 | OCTP0 | OCTN0 | OCPOL0 | OCMODE1 | OCMODE0 | | Test<br>Register<br>(note 1) | 9 | reserved | reserved | Map<br>Internal<br>Register | Connect<br>RX<br>Buffer 0<br>CPU | Connect<br>TX<br>Buffer<br>CPU | Access<br>Internal<br>Bus | Normal<br>RAM<br>Connect | Float<br>Output<br>Driver | | Transmit Bu | uffer | | | | | | | | | | Identifier | 10 | ID.10 | ID.9 | ID.8 | ID.7 | ID.6 | ID.5 | ID.4 | ID.3 | | RTR, Data<br>Length<br>Code | 11 | ID.2 | ID.1 | ID.0 | RTR | DLC.3 | DLC.2 | DLC.1 | DLC.0 | | bytes 1-8 | 12–19 | Data | Receive Bu | ffer 0/1 | | | | | · · · · · · · · · · · · · · · · · · · | | | | | Identifier | 20 | ID.10 | ID.9 | ID.8 | ID.7 | ID.6 | ID.5 | ID.4 | ID.3 | | RTR, Data<br>Length<br>Code | 21 | ID.2 | ID.1 | ID.0 | RTR | DLC.3 | DLC.2 | DLC.1 | DLC.0 | | bytes 1-8 | 22-29 | Data | Clock<br>Divider | 31 | reserved | reserved | reserved | reserved | reserved | CD.2 | CD.1 | CD.0 | #### Notes - 1. The Test Register is used for production testing only. - 2. Register 30 is not implemented. 82C200 #### 6.2.1 CONTROL REGISTER (CR) The contents of the Control Register are used to change the behaviour of the PCX82C200. Control bits may be set or reset by the attached microcontroller which uses the Control Register as a read/write memory. Table 2 Description of the Control Register bits | CR | | | | ADDRESS 0 | |-----------------------------------------|--------|------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BIT | SYMBOL | NAME | VALUE | FUNCTION | | CR.7 | TM | Test Mode<br>(note 1) | HIGH (enabled) | PCX82C200 enters Test Mode (normal operation impossible). | | | 7 | | LOW (disabled) | Normal operating mode. | | CR.6 | S | Sync<br>(note 2) | HIGH (2 edges) | Bus-line transitions from recessive-to-dominant and vice versa are used for resynchronization (see sections 7.2 and 8). | | | | | LOW (1 edge) | Only transitions from recessive-to-dominant are used for resynchronization. | | CR.5 | - | - | - | Reserved. | | CR.4 | OIE | Overrun<br>Interrupt Enable | HIGH (enabled) | If the Data Overrun bit is set (see section 6.2.3), the microcontroller receives an Overrun Interrupt signal. | | | | | LOW (disabled) | Microcontroller receives no Overrun Interrupt signal from the PCX82C200. | | CR.3 | EIE | Error Interrupt<br>Enable | HIGH (enabled) | If the Error or Bus Status change (see section 6.2.3), the microcontroller receives an Error Interrupt signal. | | | | | LOW (disabled) | Microcontroller receives no Error Interrupt signal. | | CR.2 | TIE | Transmit<br>Interrupt Enable | HIGH (enabled) | When a message has been successfully transmitted or the transmit buffer is accessible again, (e.g. after an Abort Transmission command) the PCX82C200 transmits a Transmit Interrupt signal to the microcontroller. | | | | | LOW (disabled) | No transmission of the Transmit Interrupt signal by the PCX82C200 to the microcontroller. | | CR.1 | RIE | Receive<br>Interrupt Enable | HIGH (enabled) | When a message has been received without errors, the PCX82C200 transmits a Receive Interrupt signal to the microcontroller. | | - | | | LOW (disabled) | No transmission of the Receive Interrupt signal by the PCX82C200 to the microcontroller. | | CR.0 | RR | Reset Request (note 3) | HIGH (present) | Detection of a Reset Request results in the PCX82C200 aborting the current transmission or reception of a message and entering the reset state. | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | LOW (absent) | On the HIGH-to-LOW transition of the Reset Request bit, the PCX82C200 returns to its normal operating state. | #### Notes - 1. The Test Mode is intended for factory testing and not for customer use. - The Sync bit should only be modified if the Reset Request bit is set HIGH (present), otherwise it is ignored. It is possible to set the Sync bit while the Reset Request bit is changed from HIGH to LOW. - 3. During an external reset (<del>RST</del> = LOW) or when the Bus Status bit is set HIGH (Bus-Off), the IML forces the Reset Request HIGH (present). During an external reset the microcontroller cannot set the Reset Request bit LOW (absent). Therefore, after having set the Reset Request bit LOW (absent), the microcontroller must check this bit to ensure that the external reset pin is not being held HIGH (present). After the Reset Request bit is set LOW (absent) the PCX82C200 will wait for: - one occurrence of the Bus-Free signal (11 recessive bits, see section 8.9.6), if the preceding reset (Reset Request = HIGH) was due to an external reset or a microcontroller initiated reset - 128 occurrences of Bus-Free, if the preceding reset (Reset Request = HIGH) was due to a PCX82C200 initiated Bus-Off, before re-entering the Bus-On mode (see section 8.9). When Reset Request is set HIGH (present), for whatever reason, the control, command, status and interrupt bits are affected, see Table 3. When Reset Request is set HIGH (present) the registers at addresses 4 to 8 are accessible but the TBF is not. 82C200 Table 3 Effects of setting the Reset Request bit HIGH (present) | TYPE | BIT | FUNCTION | | EFFECT | |-----------|-------|------------------------------|------|---------------------| | Control | CR.7 | Test Mode | LOW | (disabled) | | Command | CMR.4 | Goto Sleep | LOW | (wake-up) | | | CMR.3 | Clear Overrun Status | HIGH | (clear) | | | CMR.2 | Release Receive Buffer | HIGH | (released) | | | CMR.1 | Abort Transmission | LOW | (absent) | | | CMR.0 | Transmission Request | LOW | (absent) | | Status | SR.7 | Bus Status | LOW | (Bus-On) (note 1) | | | SR.6 | Error Status | LOW | (no error) (note 1) | | | SR.5 | Transmit Status | LOW | (idle) | | | SR.4 | Receive Status | LOW | (idle) | | | SR.3 | Transmission Complete Status | HIGH | (complete) | | | SR.2 | Transmit Buffer Access | HIGH | (released) | | | SR.1 | Data Overrun | LOW | (absent) | | | SR.0 | Receive Buffer Status | LOW | (empty) | | Interrupt | IR.3 | Overrun Interrupt | LOW | (reset) | | erio | IR.1 | Transmit Interrupt | LOW | (reset) | | | IR.0 | Receive Interrupt | LOW | (reset) | #### Note 1. Only after an external reset; see note 1 to Table 5 "Description of the Status Register bits". 82C200 #### 6.2.2 COMMAND REGISTER (CMR) A command bit initiates an action within the transfer layer of the PCX82C200. The Command Register appears to the microcontroller as a write only memory. If a read access is performed to this address the byte 11111111 (binary) is returned. Table 4 Description of the Command Register bits | CMR | ADDRESS 1 | | | | | | | | |-------|-----------|-------------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | BIT | SYMBOL | NAME | VALUE | FUNCTION | | | | | | CMR.7 | _ | | | Reserved. | | | | | | CMR.6 | = | _ | - | Reserved. | | | | | | CMR.5 | _ | _ | - | Reserved. | | | | | | CMR.4 | GTS | GoTo Sleep<br>(note 1) | HIGH (sleep) | The PCX82C200 enters sleep mode, if the INT = HIGH (no interrupt signal from the PCX82C200 to the microcontroller pending or external source pending) and there is no bus activity. | | | | | | , | , | | LOW (wake up) | The PCX82C200 functions normally. | | | | | | CMR.3 | cos | Clear Overrun<br>Status | HIGH (clear) | The Data Overrun status bit is set to LOW (see section 6.2.3). | | | | | | | | (note 2) | LOW (no action) | No action. | | | | | | CMR.2 | RRB | Release Receive<br>Buffer | HIGH (released) | The receive buffer attached to the microcontroller is released. | | | | | | | | (note 3) | LOW (no action) | No action. | | | | | | CMR.1 | AT | Abort<br>Transmission | HIGH (present) | If not already in progress, a pending Transmission Request is cancelled. | | | | | | | | (note 4) | LOW (absent) | No action. | | | | | | CMR.0 | TR | transmission<br>Request<br>(note 5) | HIGH (present)<br>LOW (absent) | A message shall be transmitted. No action. | | | | | #### Notes - 1. The PCX82C200 will enter sleep mode, if Goto Sleep is set HIGH (sleep), there is no bus activity and \$\overline{\text{INT}}\$ = HIGH (inactive). After sleep mode is set, the CLK OUT signal continues until at least 15 bit times have passed. The PCX82C200 will wake up when one of the three previously mentioned conditions is negated: after Goto Sleep is set LOW (wake up), there is bus activity or \$\overline{\text{INT}}\$ is driven LOW (active). On wake up, the oscillator is started and a Wake-Up Interrupt (see section 6.2.4) is generated. A PCX82C200 which is sleeping and then awakened by bus activity will not be able to receive this message until it detects a Bus-Free signal (see section 8.9.6). - This command bit is used to acknowledge the Data Overrun condition signalled by the Data Overrun status bit. It may be given or set at the same time as a Release Receive Buffer command bit. - After reading the contents of the Receive Buffer (RBF0 or RBF1) the microcontroller must release this buffer by setting the Release Receive Buffer bit HIGH (released). This may result in another message becoming immediately available. - 4. The Abort Transmission bit is used when the microcontroller requires the suspension of the previously requested transmission, for example to transmit an urgent message. A transmission already in progress is not stopped. In order to determine if the original message had been transmitted successfully, or aborted, the Transmission Complete status bit should be checked after the Transmit Buffer Access bit has been set HIGH (released) or a Transmit Interrupt has been generated (see section 6.2.4). - If the Transmission Request bit was set HIGH in a previous command, it cannot be cancelled by setting the Transmission Request bit LOW (absent). Cancellation of the requested transmission may be performed by setting the Abort Transmission bit HIGH (present). November 1992 374 82C200 #### 6.2.3 STATUS REGISTER (SR) The contents of the Status Register reflect the status of the PCX82C200 bus controller. The Status Register appears to the microcontroller as a read only memory. Table 5 Description of the Status Register bits | SR | | ADDRESS 2 | | | | | | | | |------|----------------------|---------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | BIT | SYMBOL | NAME | VALUE | FUNCTION | | | | | | | SR.7 | BS | Bus Status | HIGH (Bus-Off) | The PCX82C200 is not involved in bus activities. | | | | | | | | | (note 1) | LOW (Bus-On) | The PCX82C200 is involved in bus activities. | | | | | | | SR.6 | ES | Error Status | HIGH (error) | At least one of the Error Counters (see section 8.10.3) has reached the microcontroller Warning Limit. | | | | | | | | | | LOW (ok) | Both Error Counters have not reached the Warning Limit. | | | | | | | SR.5 | TS | Transmit Status | HIGH (transmit) | The PCX82C200 is transmitting a message. | | | | | | | | | (note 2) | LOW (idle) | No message is transmitted. | | | | | | | SR.4 | RS | Receive Status | HIGH (receive) | The PCX82C200 is receiving a message. | | | | | | | | | (note 2) | LOW (idle) | No message is received. | | | | | | | SR.3 | TCS | Transmission<br>Complete Status | HIGH (complete) | Last requested transmission has been successfully completed. | | | | | | | | | (note 3) | LOW<br>(incomplete) | Previously requested transmission is not yet completed. | | | | | | | SR.2 | TBS | Transmit Buffer | HIGH (released) | The microcontroller may write a message into the TBF. | | | | | | | | ing said<br>and said | Access<br>(note 3) | LOW (locked) | The microcontroller cannot access the Transmit Buffer. A message is either waiting for transmission or is in the process of being transmitted. | | | | | | | SR.1 | DO | Data Overrun<br>(note 4) | HIGH (overrun) | This bit is set HIGH (Overrun), when both Receive Buffers are full and the first byte of another message should be stored. | | | | | | | | | | LOW (absent) | No data overrun has occurred since the Clear Overrun command was given. | | | | | | | SR.0 | RBS | Receive Buffer | HIGH (full) | This bit is set when a new message is available. | | | | | | | | Negrij<br>Bestining | Status<br>(note 5) | LOW (empty) | No message has become available since the last Release Receive Buffer command bit was set. | | | | | | #### Notes - 1. When the Bus Status bit is set HIGH (Bus-Off), the PCX82C200 will set the Reset Request bit HIGH (present). It will stay in this state until the microcontroller sets the Reset Request bit LOW (absent). Once this is completed the PCX82C200 will wait the minimum protocol-defined time (128 occurrences of the Bus-Free signal) before setting the Bus Status bit LOW (Bus-On), the Error Status bit LOW (ok) and resetting the Error Counters. - 2. If both the Receive Status and Transmit Status bits are LOW (idle) the CAN-bus is idle. - 3. If the microcontroller tries to write to the Transmit Buffer when the Transmit Buffer Access bit is LOW (locked), the written bytes will not be accepted and will be lost without this being signalled. The Transmission Complete Status bit is set LOW (incomplete) whenever the Transmission Request bit is set HIGH (present). If an Abort Transmission command is issued, the Transmit Buffer will be released. If the message, which was requested and then aborted, was not transmitted, the Transmission Complete Status bit will remain LOW. - 4. If Data Overrun = HIGH (Overrun) is detected, the currently received message is dropped. A transmitted message, granted acceptance, is also stored in a Receive Buffer. This occurs because it is not known if the PCX82C200 will lose arbitration and so become a receiver of the message. If no Receive Buffer is available, Data Overrun is signalled. - 5. If the command bit Release Receive Buffer is set HIGH (released) by the microcontroller, the Receive Buffer Status bit is set LOW (empty) by IML. When a new message is stored in any of the receive buffers, the Receive Buffer Status bit is set HIGH (full) again. 82C200 #### 6.2.4 INTERRUPT REGISTER (IR) The Interrupt Register allows the identification of an interrupt source. When one or more bits of this register are set, the $\overline{\text{INT}}$ pin is activated. All bits are reset by the PCX82C200 after this register is read by the microcontroller. This register appears to the microcontroller as a read only memory. Table 6 Description of the Interrupt Register bits | IR | | | AD | DRESS 3 | |------|--------|-------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BIT | SYMBOL | NAME | VALUE | FUNCTION | | IR.7 | - | - | | Reserved. | | IR.6 | | - | # 15 page 11 pag | Reserved. | | IR.5 | - | - | | Reserved. | | IR.4 | WUI | Wake-Up<br>Interrupt | HIGH (set) | The Wake-Up Interrupt bit is set HIGH, when the sleep mode is left (see section 6.2.2). | | | , v | | LOW (reset) | Wake-Up Interrupt bit is reset by a read access of<br>Interrupt Register by the microcontroller. | | IR.3 | OI | Overrun Interrupt<br>(note 1) | HIGH (set) | This bit is set HIGH, if both Receive Buffers contain a message and the first byte of another message should be stored (passed acceptance), and the Overrun Interrupt Enable is HIGH (enabled). | | | | | LOW (reset) | Overrun Interrupt bit is reset by a read access of Interrupt Register by the microcontroller. | | IR.2 | EI | Error Interrupt | HIGH (set) | This bit is set on a change of either the Error Status or Bus Status bits (see section 6.2.3) if the Error Interrupt Enable is HIGH (enabled). | | | | | LOW (reset) | The Error Interrupt bit is reset by a read access of the Interrupt Register by the microcontroller. | | IR.1 | TI | Transmit Interrupt | HIGH (set) | This bit is set on a change of the Transmit Buffer<br>Access bit from LOW to HIGH (released) and Transmit<br>Interrupt Enable is HIGH (enabled). | | | | | LOW (reset) | Transmit Interrupt bit will be reset after a read access of the Interrupt Register by the microcontroller. | | IR.0 | RI | Receive Interrupt<br>(note 2) | HIGH (set) | This bit is set when a new message is available in the Receive Buffer and the Receive Interrupt Enable bit is HIGH (enabled). | | | | | LOW (reset) | Receive Interrupt bit is automatically reset by a read access of Interrupt Register by the microcontroller. | #### Notes - 1. Overrun Interrupt bit (if enabled) and Data Overrun bit (see section 6.2.3) are set at the same time. - 2. Receive Interrupt bit (if enabled) and Receive Buffer Status bit (see section 6.2.3) are set at the same time. November 1992 376 82C200 ## 6.2.5 ACCEPTANCE CODE REGISTER (ACR) The Acceptance Code Register is part of the acceptance filter of the PCX82C200. This register can be accessed (read/write), if the Reset Request bit is set HIGH (present). When a message is received which passes the acceptance test and if there is an empty Receive Buffer, then the respective Descriptor and Data Field (see Fig.4) are sequentially stored in this empty buffer. In the case that there is no empty Receive Buffer, the Data Overrun bit is set HIGH (overrun), see sections 6.2.3 and 6.2.4. When the complete message has been correctly received the following - . the Receive Buffer Status bit is set HIGH (full) - if the Receive Interrupt Enable bit is set HIGH (enabled), the Receive Interrupt is set HIGH (set). The Acceptance Code bits (AC.7-AC.0) and the eight most significant bits of the message's Identifier (ID.10-ID.3) must be equal to those bit positions which are marked relevant by the Acceptance Mask bits (AM.7-AM.0). If the following equation is satisfied, acceptance is given: $$[(ID.10..ID.3) = (AC.7..AC.0)]$$ or $(AM.7..AM.0) = 1111.1111$ binary During transmission of a message which passes the acceptance test, the message is also written to its own Receive Buffer. If no Receiver Buffer is available, Data Overrun is signalled because it is not known at the start of a message whether the PCX82C200 will lose arbitration and so become a receiver of the message. Table 7 Acceptance Code Register bits | ACR | | ADDRESS 4 | | | | | | |------|------|-----------|------|------|------|------|---------| | 7 | 6 | 5 | 4 | 3 | 2 | √1 - | 0.74.77 | | AC.7 | AC.6 | AC.5 | AC.4 | AC.3 | AC.2 | AC.1 | AC.0 | #### 6.2.6 ACCEPTANCE MASK REGISTER (AMR) The Acceptance Mask Register is part of the acceptance filter of the PCX82C200. This register can be accessed (read/write) if the Reset Request bit is set HIGH (present). The Acceptance Mask Register qualifies which of the corresponding bits of the acceptance code are "relevant" or "don't care" for acceptance filtering. Table 8 Acceptance Mask Register bits | AMR | | | я . | ADDRESS 5 | | | | |------|------|------|------|-----------|------|------|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | AM.7 | AM.6 | AM.5 | AM.4 | AM.3 | AM.2 | AM.1 | AM.0 | Table 9 Description of the Acceptance Mask Register bits | ACCEPTANCE MASK BIT | VALUE | COMMENTS | |--------------------------------|----------------|--------------------------------------------------------------------| | AM.7 to AM.0 HIGH (don't care) | | This bit position is "don't care" for the acceptance of a message. | | | LOW (relevant) | This bit position is "relevant" for acceptance filtering. | 82C200 #### 6.2.7 Bus Timing Register 0 (BTR0) The contents of Bus Timing Register 0 defines the values of Baud Rate Prescaler (BRP) and the Synchronization Jump Width (SJW). This register can be accessed (read/write) if the Reset Request bit is set HIGH (present). Table 10 Bus Timing Register 0 bits | BTR0 | | | | ADDRESS 6 | | | | |-------|-------|-------|-------|-----------|-------|-------|-------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SJW.1 | SJW.0 | BRP.5 | BRP.4 | BRP.3 | BRP.2 | BRP.1 | BRP.0 | #### Baud Rate Prescaler (BRP) The period of the system clock t<sub>SCL</sub> is programmable and determines the individual bit timing. The system clock is calculated using the following equation: $$t_{SCL} = 2t_{CLK} (32BRP.5 + 16BRP.4 + 8BRP.3 + 4BRP.2 + 2BRP.1 + BRP.0 + 1)$$ $t_{CLK}$ = time period of the PCX82C200 oscillator. #### Synchronization Jump Width (SJW) To compensate for phase shifts between clock oscillators of different bus controllers, any bus controller must resynchronize on any relevant signal edge of the current transmission. The synchronization jump width defines the maximum number of clock cycles a bit period may be shortened or lengthened by one resynchronization: $$t_{SJW} = t_{SCL} (2SJW.1 + SJW.0 + 1)$$ For further information on bus timing see sections 6.2.8 and 7. #### 6.2.8 Bus Timing Register 1 (BTR1) The contents of Bus Timing Register 1 defines the length of the bit period, the location of the sample point and the number of samples to be taken at each sample point. This register may be accessed (read/write) if the Reset Request bit is set HIGH (present). Table 11 Bus Timing Register 1 bits | BTR1 | ADDRESS 7 | | | | | | | |------|-----------|---------|---------|---------|---------|---------|---------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SAM | TSEG2.2 | TSEG2.1 | TSEG2.0 | TSEG1.3 | TSEG1.2 | TSEG1.1 | TSEG1.0 | #### Sampling (SAM) Table 12 Selection of sampling | BIT | VALUE | COMMENTS | |----------------------|----------------|--------------------------| | SAM HIGH (3 samples) | | Three samples are taken. | | | LOW (1 sample) | The bus is sampled once. | SAM = LOW (logic 0) is recommended for high speed buses (SAE class C), while SAM = HIGH (logic 1) is recommended for slow/medium speed buses (class A and B) where filtering of spikes on the bus-line is beneficial (see section 7.1.6). ## 82C200 Time Segment 1 (TSEG1) and Time Segment 2 (TSEG2) TSEG1 and TSEG2 determine the number of clock cycles per bit period and the location of the sample point: $t_{TSEG1} = t_{SCL} (8TSEG1.3 + 4TSEG1.2 + 2TSEG1.1 + TSEG1.0 + 1)$ $t_{\mathsf{TSEG2}} = t_{\mathsf{SCL}} \; (\mathsf{4TSEG2.2} + \mathsf{2TSEG2.1} + \mathsf{TSEG2.0} + \mathsf{1})$ For further information on bus timing see sections 6.2.7 and 7. 6.2.9 OUTPUT CONTROL REGISTER (OCR) The Output Control Register allows, under software control, the set-up of different output driver configurations. This register may be accessed (read/write) if the Reset Request bit is set HIGH (present). Table 13 Output Control Register bits | ſ | OCR | | | - 12 | ADDRESS 8 | | | | |---|-------|-------|--------|-------|-----------|--------|---------|---------| | T | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | t | OCTP1 | OCTN1 | OCPOL1 | OCTP0 | OCTN0 | OCPOL0 | OCMODE1 | OCMODE0 | If the PCX82C200 is in the sleep mode (Goto Sleep = HIGH) a recessive level is output on the TX0 and TX1 pins. If the PCX82C200 is in the reset state (Reset Request = HIGH) the output drivers are floating. #### Normal Output Mode In Normal Output Mode the bit sequence (TXD) is sent via TX0 and TX1. The voltage levels on the output driver pins TX1 and TX0 depend on both the driver characteristic programmed by OCTPx, OCTNx (float, pull-up, pull-down, push-pull) and the output polarity programmed by OCPOLx (see Fig.4). 82C200 ## Clock Output Mode For the TX0 pin this is the same as in Normal Output Mode. However, the data stream to TX1 is replaced by the transmit clock (TXCLK). The rising edge of the transmit clock (non inverted) marks the beginning of a bit period. The clock pulse width is $t_{\rm SCL}$ . #### Bi-phase Output Mode In contrast to Normal Output Mode the bit representation is time variant and toggled. If the bus controllers are galvanically decoupled from the bus-line by a transformer, the bit stream is not allowed to contain a DC component. This is achieved by the following scheme. During recessive bits all outputs are deactivated (3-state). Dominant bits are sent alternatingly on TX0 and TX1, i.e. the first dominant bit is sent on TX0, the second is sent on TX1, and the third one is sent on TX0 again, etc. #### Test Output Mode For the TX0 pin this is the same as in Normal Output Mode. To measure the delay time of the transmitter and receiver this mode connects the output of the input comparator (COMP OUT) with the input of the output driver TX1. This mode is used for production testing only. The following two tables, Table 14 and Table 15, show the relationship between the bits of the Output Control Register and the two serial output pins TX0 and TX1 of the PCX82C200, connected to the serial bus (see Fig.1). Table 14 Description of the Output Mode bits | OCMODE1 | OCMODE0 | DESCRIPTION | |---------|---------|---------------------------------------------------------------| | 1 | 0 | Normal Output Mode; TX0, TX1: bit sequence (TXD; note 1). | | 1 | 1 | Clock Output Mode; TX0: bit sequence, TX1: bus clock (TXCLK). | | 0 | 0 | Bi-phase Output Mode. | | 0 | 1 | Test Output Mode; TX0: bit sequence, TX1: COMP OUT. | #### Note 1. TXD is the data bit to be transmitted. Table 15 Output pin set-up | DRIVE | ОСТРх | OCTNx | OCPOLx | TXD | TPx<br>(note 1) | TNx<br>(note 2) | TXx<br>(note 3) | |-----------|-------------------------------------------|-------|--------|-----|-----------------|-----------------|-----------------| | Float | 0 | 0 | 0 | 0 | OFF | OFF | float | | | 0 | 0 | 0 | 1 | OFF | OFF | float | | | 0 | 0 | 1. | 0 | OFF | OFF | float | | | 0 | 0 | 1 | 1 | OFF | OFF | float | | Pull-down | 0 | 1 | 0 | 0 | OFF | ON | LOW | | | 0 | 1 | 0 | 1 | OFF | OFF | float | | | 0 | 1 | 1 | 0 | OFF | OFF | float | | | 0 | 1 | 1 | 1 | OFF | ON | LOW | | Pull-up | 1 | 0 0 | 0 | 0 | OFF | OFF | float | | | 1 | 0 | 0 | 1 | ON | OFF | HIGH | | 110 | 1 | 0 | 1 | 0 | ON | OFF | HIGH | | | 1 | 0 | 1 | 1 | OFF | OFF | float | | Push/Pull | 1 | 1 | 0 | 0 | OFF | ON | LOW | | | 1 | 1 | 0 | 1 | ON | OFF | HIGH | | | o 100 11 11 11 11 11 11 11 11 11 11 11 11 | 1 1 | 1 1 | 0 | ON | OFF | HIGH | | | 1 | 1 | 1 | 1 | OFF | ON | LOW | #### Notes - 1. TPx is the on-chip output transistor x, connected to $V_{DD}$ ; x = 0 or 1. - 2. TNx is the on-chip output transistor x, connected to $V_{SS}$ ; x = 0 or 1. - 3. TXx is the serial output level on pin TX0 or TX1. It is required that the output level on the CAN-bus is dominant with TXD = 0 and recessive with TXD = 1 (see section 8.1.1). #### 6.2.10 TEST REGISTER (TR) The Test Register is used for production testing only. 82C200 #### 6.3 Transmit Buffer layout The global layout of the Transmit Buffer is shown in Fig.3. This buffer serves to store a message from the microcontroller to be transmitted by the PCX82C200. It is subdivided into Descriptor and Data Field. The Transmit Buffer can be written to and read from by the microcontroller (see note 3 to Table 2). #### 6.3.1 DESCRIPTOR Table 16 Descriptor Byte 1 (DSCR1) | DSCR1 | | | ADDRESS 10 | | | | | |-------|------|------|------------|------|------|------|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ID.10 | ID.9 | ID.8 | ID.7 | ID.6 | ID.5 | ID.4 | ID.3 | Table 17 Descriptor Byte 2 (DSCR2) | DSCR2 | | | | ADDRESS 11 | | | | |-------|------|------|-----|------------|-------|-------|-------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ID.2 | ID.1 | ID.0 | RTR | DLC.3 | DLC.2 | DLC.1 | DLC.0 | #### Identifier (ID) The Identifier consists of 11 bits (ID.10 to ID.0). ID.10 is the most significant bit, which is transmitted first on the bus during the arbitration process. The Identifier acts as the message's name, used in a receiver for acceptance filtering and also determines the bus access priority during the arbitration process. The lower the binary value of the Identifier the higher the priority. This is due to the larger number of leading dominant bits during arbitration (see section 8.7 "Bus organization"). Remote Transmission Request bit (RTR) Table 18 Description of the RTR bit | BIT | VALUE | COMMENTS | | | | |-------------------|-------|----------------------------------------------------|--|--|--| | RTR HIGH (remote) | | Remote Frame will be transmitted by the PCX82C200. | | | | | LOW (data) | | Data Frame will be transmitted by the PCX82C200. | | | | #### Data Length Code (DLC) The number of bytes (Data Byte Count) in the Data Field of a message is coded by the Data Length Code. At the start of a Remote Frame transmission the Data Length Code is not considered due to the RTR bit being HIGH (remote). This forces the number of transmitted/received data bytes to be 0. Nevertheless, the Data Length Code must be specified correctly to avoid bus errors, if two CAN-controllers start a Remote Frame transmission simultaneously. The range of the Data Byte Count is 0 to 8 bytes and coded as follows: Data Byte Count = 8DLC.3 + 4DLC.2 + 2DLC.1 + DLC.0 For reasons of compatibility no Data Byte Counts other than 0 to 8 should be used. #### 6.3.2 DATA FIELD The number of transferred data bytes is determined by the Data Length Code. The first bit transmitted is the most significant bit of data byte 1 at address 12. 82C200 #### 6.4 Receive Buffer layout The layout of the Receive Buffer and the individual bytes correspond to the definitions given for the Transmit Buffer layout, except that the addresses start at 20 instead of 10 (see Fig.3). ### 6.5 Clock Divider Register (CDR) The Clock Divider Register controls the CLK OUT frequency for the microcontroller (see Fig.1). It can be written to or read by the microcontroller. The default state of the register is divide by 12 for Motorola mode and divide by 2 for Intel mode. Values from 0 to 7 may be written into this register and will result in the CLK OUT frequencies shown in Table 20. Table 19 Clock Divider Register bits | CDR | | | | ADDRESS 31 | | | | |-----|---|---|---|------------|------|------|------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | _ | | | | - 7 | CD.2 | CD.1 | CD.0 | #### Note Bits CDR.7 to CDR.3 are reserved. Table 20 CLK OUT frequency selection | CD.2 | CD.1 | CD.0 | CLK OUT FREQUENCY | |------|------|------|----------------------| | 0 | 0 | 0 | f <sub>CLK</sub> /2 | | 0 | 0 | 1 | f <sub>CLK</sub> /4 | | 1 | 1 | 0 | f <sub>CLK</sub> /6 | | 0 | 1 | 1. | f <sub>CLK</sub> /8 | | 1 | 0 | 0 | f <sub>cLK</sub> /10 | | 1 | 0 | 1 | f <sub>CLK</sub> /12 | | 1 | 1 | 0 | f <sub>CLK</sub> /14 | | 1 | 1 | 1" | fcik | #### Note 1. $f_{\text{CLK}}$ is the frequency of the oscillator. 82C200 #### 7 BUS TIMING/SYNCHRONIZATION The Bus Timing Logic (BTL) monitors the serial bus-line via the on-chip input comparator and performs the following functions (see section 5): - · monitors the serial bus-line level - adjusts the sample point, within a bit period (programmable) - samples the bus-line level using majority logic (programmable, 1 or 3 samples) - · synchronization to the bit stream: - hard synchronization at the start of a message - resynchronization during transfer of a message. The configuration of the BTL is performed during the initialization of the PCX82C200. The BTL uses the following three registers: - · Control register (Sync) - . Bus Timing Register 0 - · Bus Timing Register 1. #### 7.1 Bit timing A bit period is built up from a number of system clock cycles ( $t_{\rm SCL}$ ), see section 6.2.7. One bit period is the result of the addition of the programmable segments TSEG1 and TSEG2 and the general segment SYNCSEG (see sections 6.2.7 to 6.2.8). #### 7.1.1 SYNCHRONIZATION SEGMENT (SYNCSEG) The incoming edge of a bit is expected during this state; this state corresponds to one system clock cycle (1 x $t_{sci}$ ). #### 7.1.2 TIME SEGMENT 1 (TSEG1) This segment determines the location of the sampling point within a bit period, which is at the end of TSEG1. TSEG1 is programmable from 1 to 16 system clock cycles (see section 6.2.8). The correct location of the sample point is essential for the correct functioning of a transmission. The following points must be taken into consideration: - a Start-Of-Frame (see section 8.2.1) causes all PCX82C200's to perform a 'hard synchronization' (see section 7.2.1) on the first recessive-to-dominant edge. During arbitration, however, several PCX82C200's may simultaneously transmit. Therefore it may require twice the sum of bus-line, input comparator and the output driver delay times until the bus is stable. This is the propagation delay time. - to avoid sampling at an incorrect position, it is necessary to include an additional synchronization buffer on both sides of the sample point. The main reasons for incorrect sampling are: - incorrect synchronization due to spikes on the bus-line - slight variations in the oscillator frequency of each PCX82C200 in the network, which results in a phase error. Time Segment 1 consists of the segment for compensation of propagation delays and the synchronization buffer directly before the sample point (see Fig.5). #### 7.1.3 TIME SEGMENT 2 (TSEG2) This time segment provides: - additional time at the sample point for calculation of the subsequent bit levels (e.g. arbitration) - synchronization buffer segment directly after the sample point (see section 7.1.2). TSEG2 is programmable from 1 to 8 system clock cycles (see section 6.2.8). 82C200 82C200 #### 7.1.4 SYNCHRONIZATION JUMP WIDTH (SJW) SJW defines the maximum number of clock cycles (t<sub>sct</sub>) a bit period may be reduced or increased by one resynchronization. SJW is programmable from 1 to 4 system clock cycles (see section 6.2.7). #### 7.1.5 PROPAGATION DELAY TIME The propagation delay time $(t_{prop})$ is calculated by summing the maximum propagation delay times of the physical bus, the input comparator and the output driver. The resulting sum is multiplied by 2 and then rounded up to the nearest multiple of $t_{SCL}$ . $t_{\text{prop}} = 2 \text{ x (physical bus delay + input comparator delay + output driver delay)}$ #### 7.1.6 BIT TIMING RESTRICTIONS Restrictions on the configuration of the bit timing are based on internal processing. The restrictions are: - $t_{TSEG2} \ge 2t_{SCL}$ - $t_{TSEG2} \ge t_{SJW}$ - $t_{TSEG1} \ge t_{TSEG2}$ - $t_{TSEG1} \ge t_{SJW} + t_{proc}$ The three sample mode (SAM = 1) has the effect of introducing a delay of one system clock cycle on the bus-line. This must be taken into account for the correct calculation of TSEG1 and TSEG2: - $t_{TSEG1} \ge t_{SJW} + t_{prop} + 2t_{SCL}$ - $t_{TSEG2} \ge 3t_{SCL}$ ## 7.2 Synchronization Synchronization is performed by a state machine which compares the incoming edge with its actual bit timing and adapts the bit timing by hard synchronization or resynchronization. #### 7.2.1 HARD SYNCHRONIZATION This type of synchronization occurs only at the beginning of a message. The PCX82C200 synchronizes on the first incoming recessive-to-dominant edge of a message (being the leading edge of a message's Start-Of-Frame bit; see section 7.1). #### 7.2.2 RESYNCHRONIZATION Resynchronization occurs during the transmission of a message's bit stream to compensate for: - variations in individual PCX82C200 oscillator frequencies - changes introduced by switching from one transmitter to another (e.g. during arbitration). As a result of resynchronization either $t_{\mathsf{TSEG1}}$ may be increased by up to a maximum of $t_{\mathsf{S.W}}$ or $t_{\mathsf{TSEG2}}$ may be decreased by up to a maximum of $t_{\mathsf{S.W}}$ . - $t_{TSEG1} \le t_{SCI} ((TSEG1 + 1) + (SJW + 1))$ - $t_{TSEG2} \ge t_{SCL} ((TSEG2 + 1) (SJW + 1))$ Note: TSEG1, TSEG2 and SJW are the programmed numerical values. The phase error (e) of an edge is given by the position of the edge relative to SYNCSEG, measured in system clock cycles ( $t_{SCL}$ ). The value of the phase error is defined as: - e = 0, if the edge occurs within SYNCSEG - e > 0, if the edge occurs within TSEG1 - e < 0, if the edge occurs within TSEG2. The effect of resynchronization is: - the same as that of a hard synchronization, if the magnitude of the phase error (e) is less or equal to the programmed value of t<sub>s.w</sub> (see section 6.2.7) - to increase a bit period by the amount of t<sub>SJW</sub>, if the phase error is positive and the magnitude of the phase error is larger than t<sub>SJW</sub> - to decrease a bit period by the amount of t<sub>SJW</sub>, if the phase error is negative and the magnitude of the phase error is larger than t<sub>SJW</sub>. #### 7.2.3 SYNCHRONIZATION RULES The synchronization rules are as follows: - only one synchronization within one bit time is used - an edge is used for synchronization only if the value detected at the previous sample point differs from the bus value immediately after the edge - hard synchronization is performed whenever there is a recessive-to-dominant edge during Bus-Idle (see section 7) Philips Semiconductors Product specification ## Stand-alone CAN-controller 82C200 - all other edges (recessive-to-dominant and optionally dominant-to-recessive edges if the Sync bit is set HIGH; see section 6.2.1) which are candidates for resynchronization will be used with the following exception: - a transmitting PCX82C200 will not perform a resynchronization as a result of a recessive-to-dominant edge with positive phase error, if only these edges are used for resynchronization. This ensures that the delay times of the output driver and input comparator do not cause a permanent increase in the bit time. #### **8 COMMUNICATION PROTOCOL** #### 8.1 Frame types The PCX82C200 bus controller supports the four different CAN-protocol frame types for communication: - · Data Frame, to transfer data - · Remote Frame, request for data - Error Frame, globally signal a (locally) detected error condition - Overload Frame, to extend delay time of subsequent frames (an Overload Frame is not initiated by the PCX82C200). #### 8.1.1 BIT REPRESENTATION There are two logical bit representations used in the CAN-protocol: - a recessive bit on the bus-line appears only if all connected PCX82C200's send a recessive bit at that moment - dominant bits always overwrite recessive bits i.e. the resulting bit level on the bus-line is dominant. #### 8.2 Data Frame A Data Frame carries data from a transmitting PCX82C200 to one or more receiving PCX82C200's. A Data Frame is composed of seven different bit-fields: - · Start-Of-Frame - Arbitration Field - Control Field - . Data Field (may have a length of zero) - CRC Field - · Acknowledge Field - · End-Of-Frame. November 1992 387 Philips Semiconductors Product specification ## Stand-alone CAN-controller 82C200 #### 8.2.1 START-OF-FRAME BIT Signals the start of a Data Frame or Remote Frame. It consists of a single dominant bit used for hard synchronization of a PCX82C200 in receive mode. #### 8.2.2 ARBITRATION FIELD Consists of the message Identifier and the RTR bit (see section 6.3.1). In the event of simultaneous message transmissions by two or more PCX82C200's the bus access conflict is solved by bit-wise arbitration, which is active during the transmission of the Arbitration Field. #### Identifier This 11-bit field is used to provide information about the message, as well as the bus access priority. It is transmitted in the order ID.10 to ID.0 (LSB). The situation that the seven most significant bits (ID.10 to ID.4) are all recessive must not occur. An Identifier does not define which particular PCX82C200 will receive the frame, because a CAN based communication network does not discriminate between a point-to-point, multicast or broadcast communication. ## Remote Transmission Request bit (RTR) A PCX82C200, acting as a receiver for certain information may initiate the transmission of the respective data by transmitting a Remote Frame to the network, addressing the data source via the Identifier and setting the RTR bit HIGH (remote; recessive bus level). If the data source simultaneously transmits a Data Frame containing the requested data, it uses the same Identifier. No bus access conflict occurs due to the RTR bit being set LOW (data; dominant bus level) in the Data Frame. #### 8.2.3 CONTROL FIELD This field consists of six bits. It includes two reserved bits (for future expansions of the CAN-protocol), transmitted with a dominant bus level, and is followed by the Data Length Code (4 bits). The number of bytes in the (destuffed; number of data bytes to be transmitted/received) Data Field is indicated by the Data Length Code and hence the number of bytes in the (destuffed) Data Field, are 0 to 8. A logic 0 (logic 1) in the Data Length Code is transmitted as a dominant (recessive) bus level, respectively. #### 8.2.4 DATA FIELD The data, stored within the Data Field of the Transmit Buffer, are transmitted according to the Data Length Code. Conversely, data of a received Data Frame will be stored in the Data Field of a Receive Buffer. Data is stored byte-wise both for transmission by the microcontroller and on reception by the PCX82C200. The most significant bit of the first data byte (lowest address) is transmitted/received first. #### 8.2.5 CYCLIC REDUNDANCY CODE FIELD (CRC) The CRC Field consists of the CRC Sequence (15 bits) and the CRC Delimiter (1 recessive bit). The Cyclic Redundancy Code (CRC) encloses the destuffed bit stream of the Start-Of-Frame, Arbitration Field, Control Field, Data Field and CRC Sequence. The most significant bit of the CRC Sequence is transmitted/received first. This frame check sequence, implemented in the PCX82C200, is derived from a cyclic redundancy code best suited for frames with a total bit count of less than 127 bits, see section 8.8.3 With Start-Of-Frame (dominant bit) included in the code word, any rotation of the code word can be detected by the absence of the CRC Delimiter (recessive bit). #### 8.2.6 ACKNOWLEDGE FIELD (ACK) The Acknowledge Field consists of two bits, the Acknowledge Slot and the Acknowledge Delimiter, which are transmitted with a recessive level by the transmitter of the Data Frame. All PCX82C200's having received the matching CRC Sequence, report this by overwriting the transmitter's recessive bit in the Acknowledge Slot with a dominant bit (see section 8.9.2). Thereby a transmitter, still monitoring the bus level recognizes that at least one receiver within the network has received a complete and correct message (i.e. no error was found). The Acknowledge Delimiter (recessive bit) is the second bit of the Acknowledge Field. As a result, the Acknowledge Slot is surrounded by two recessive bits: the CRC Delimiter and the Acknowledge Delimiter. All nodes within a CAN network may use all the information coming to the network by the PCX82C200's (shared memory concept). Therefore, acknowledgement and error handling are defined to provide all information in a consistent way throughout this shared memory. Hence, there is no reason to discriminate different receivers of a message in the acknowledge field. If a November 1992 388 82C200 node is disconnected from the network due to bus failure, this particular node is no longer part of the shared memory. To identify a 'lost node' additional and application specific precautions are required. #### 8.2.7 END-OF-FRAME Each Data Frame or Remote Frame is delimited by the End-Of-Frame bit sequence which consists of seven recessive bits (exceeds the bit stuff width by two bits). Using this method a receiver detects the end of a frame independent of a previous transmission error because the receiver expects all bits up to the end of the CRC sequence to be coded by the method of bit-stuffing (see section 8.7.3). The bit-stuffing logic is deactivated during the End-Of-Frame sequence. #### 8.3 Remote Frame A PCX82C200, acting as a receiver for certain information may initiate the transmission of the respective data by transmitting a Remote Frame to the network, addressing the data source via the Identifier and setting the RTR bit HIGH (remote; recessive bus level). The Remote Frame is similar to the Data Frame with the following exceptions: - . RTR bit is set HIGH - · Data Length Code is ignored - · no Data Field contained. Note that the Data Length Code value should be the same as for the corresponding Data Frame (although this is ignored for a Remote Frame). A Remote Frame is composed of six different bit fields: - Start-Of-Frame - Arbitration Field - Control Field - CRC-Field - Acknowledge Field - · End-Of-Frame. See section 8.2 for a more detailed explanation of the Remote Frame bit fields. #### 8.4 Error Frame The Error Frame consists of two different fields. The first field is accomplished by the superimposing of Error Flags contributed from different PCX82C200s. The second field is the Error Delimiter (see Fig.7). #### 8.4.1 ERROR FLAG There are two forms of an Error Flag: - Active Error Flag, consists of six consecutive dominant bits - Passive Error Flag, consists of six consecutive recessive bits unless it is overwritten by dominant bits from other PCX82C200's. An error-active PCX82C200 (see section 8.9) detecting an error condition signals this by transmission of an Active Error Flag. This Error Flag's form violates the bit-stuffing law (see section 8.7.3) applied to all fields, from Start-Of-Frame to CRC Delimiter, or destroys the fixed form of the fields Acknowledge Field or End-Of-Frame (see Fig.6). Consequently, all other PCX82C200's detect an error condition and start transmission of an Error Flag. Therefore the sequence of dominant bits, which can be monitored on the bus, results from a superposition of different Error Flags transmitted by individual PCX82C200's. The total length of this sequence varies between six (minimum) and twelve (maximum) bits. An error-passive PCX82C200 (see section 8.9) detecting an error condition tries to signal this by transmission of a Passive Error Flag. The error-passive PCX82C200 waits for six consecutive bits with identical polarity, beginning at the start of the Passive Error Flag. The Passive Error Flag is complete when these six identical bits have been detected. #### 8.4.2 ERROR DELIMITER The Error Delimiter consists of eight recessive bits and has the same format as the Overload Delimiter. After transmission of an Error Flag, each PCX82C200 monitors the bus-line until it detects a transition from a dominant-to-recessive bit level. At this point in time, every PCX82C200 has finished sending its Error Flag and all PCX82C200's start transmission of seven recessive bits (plus the recessive bit at dominant-to-recessive transition, results in a total of eight recessive bits). After this event and an Intermission Field all error-active PCX82C200's within the network can start a transmission simultaneously. If a detected error is signalled during transmission of a Data Frame or Remote Frame, the current message is spoiled and a retransmission of the message is initiated. Philips Semiconductors Product specification ## Stand-alone CAN-controller 82C200 If a PCX82C200 monitors any deviation of the Error Frame, a new Error Frame will be transmitted. Several consecutive Error Frame's may result in the PCX82C200 becoming error-passive and leaving the network unblocked. In order to terminate an Error Flag correctly, an error-passive CAN-bus controller requires the bus to be Bus-Idle (see section 8.6.2) for at least three bit periods (if there is a local error at an error-passive receiver). Therefore a CAN-bus should not be 100% permanently loaded. #### 8.5 Overload Frame The Overload Frame consists of two fields, the Overload Flag and the Overload Delimiter. There are two conditions in the CAN-protocol which lead to the transmission of an Overload Flag: - condition 1; receiver circuitry requires more time to process the current data before receiving the next frame (receiver not ready) - condition 2; detection of a dominant bit during Intermission Field (see section 8.6.1). The transmission of an Overload Frame may only start: condition 1; during the first bit period of an expected Intermission Field condition 2; one bit period after detecting the dominant bit during Intermission Field. The PCX82C200 will never initiate transmission of a condition 1 Overload Frame and will only react on a transmitted condition 2 Overload Frame, according to the CAN-protocol. No more than two Overload Frames are generated to delay a Data Frame or a Remote Frame. Although the overall form of the Overload Frame corresponds to that of the Error Frame, an Overload Frame does not initiate or require the retransmission of the preceding frame. #### 8.5.1 OVERLOAD FLAG The Overload Flag consists of six dominant bits and has a similar format to the Error Flag. The Overload Flag's form corrupts the fixed form of the Intermission Field. All other PCX82C200's detecting the overload condition also transmit an Overload Flag (condition 2). #### 8.5.2 OVERLOAD DELIMITER The Overload Delimiter consists of eight recessive bits and takes the same form as the Error Delimiter. After transmission of an Overload Flag, each PCX82C200 monitors the bus-line until it detects a transition from a November 1992 390 82C200 dominant-to-recessive bit level. At this point in time, every PCX82C200 has finished sending its Overload Flag and all PCX82C200's start simultaneously transmitting seven more recessive bits. #### 8.6 Inter-Frame Space Data Frames and Remote Frames are separated from preceding frames (all types) by an Inter-Frame Space, consisting of an Intermission Field and a Bus-Idle. Error-passive PCX82C200's also send a Suspend Transmission (see section 8.9.5) after transmission of a message. Overload Frames and Error Frames are not preceded by an Inter-Frame Space. #### 8.6.1 INTERMISSION FIELD The Intermission Field consists of three recessive bits. During an Intermission period, no frame transmissions will be started by any PCX82C200. An Intermission is required to have a fixed time period to allow a CAN-controller to execute internal processes prior to the next receive or transmit task. #### 8.6.2 Bus-IDLE The Bus-Idle time may be of arbitrary length (minimum 0 bit). The bus is recognized to be free and a CAN-controller having information to transmit may access the bus. The detection of a dominant bit level during Bus-Idle on the bus is interpreted as the Start-Of-Frame. #### 8.7 Bus organization Bus organization is based on five basic rules described in the following paragraphs. #### 8.7.1 Bus access PCX82C200's only start transmission during the Bus-Idle state. All PCX82C200's synchronize on the leading edge of the Start-Of-Frame (hard synchronization). #### 8.7.2 ARBITRATION If two or more PCX82C200's simultaneously start transmitting, the bus access conflict is solved by a bit-wise arbitration process during transmission of the Arbitration Field. During arbitration every transmitting PCX82C200 compares its transmitted bit level with the monitored bus level. Any PCX82C200 which transmits a recessive bit and monitors a dominant bus level immediately becomes the receiver of the higher priority message on the bus without corrupting any information on the bus. Each message contains an unique Identifier and a RTR bit describing the type of data within the message. The Identifier together with the RTR bit implicitly define the message's bus access priority. During arbitration the most significant bit of the Identifier is transmitted first and the RTR bit last. The message with the lowest binary value of the Identifier and RTR bit has the highest priority. A Data Frame has higher priority than a Remote Frame due to its RTR bit having a dominant level. For every Data Frame there is an unique transmitter. For reasons of compatibility with other CAN-bus controllers, use of the Identifier binary bit pattern ID = 1111111XXXX (X being bits of arbitrary level) is forbidden. The number of available different Identifiers is 2032 (2<sup>11</sup> – 2<sup>4</sup>). #### 8.7.3 CODING/DECODING The following bit fields are coded using the bit-stuffing technique: - · Start-Of-Frame - Arbitration Field - Control Field - Data Field - · CRC Sequence. When a transmitting PCX82C200 detects five consecutive bits of identical polarity to be transmitted, a complementary (stuff) bit is inserted into the transmitted bit-stream. When a receiving PCX82C200 has monitored five consecutive bits with identical polarity in the received bit streams of the above described bit fields, it automatically deletes the next received (stuff) bit. The level of the deleted stuff bit has to be the complement of the previous bits; otherwise a Stuff Error will be detected and signalled (see section 8.8.2). The remaining bit fields or frames are of fixed form and are not coded or decoded by the method of bit-stuffing. The bit-stream in a message is coded according to the Non-Return-to-Zero (NRZ) method, i.e. during a bit period, the bit level is held constant, either recessive or dominant. 82C200 #### 8.7.4 ERROR SIGNALLING A PCX82C200 which detects an error condition, transmits an Error Flag. Whenever a Bit Error, Stuff Error, Form Error or an Acknowledgement Error is detected, transmission of an Error Flag is started at the next bit. Whenever a CRC Error is detected, transmission of an Error Flag starts at the bit following the Acknowledge Delimiter, unless an Error Flag for another error condition has already started. An Error Flag violates the bit-stuffing law or corrupts the fixed form bit fields. A violation of the bit-stuffing law affects any PCX82C200 which detects the error condition. These devices will also transmit an Error Flag. An error-passive PCX82C200 (see section 8.9) which detects an error condition, transmits a Passive Error Flag. A Passive Error Flag is not able to interrupt a current message at different PCX82C200's, but this type of Error Flag may be cancelled by other PCX82C200's. After having detected an error condition, an error-passive PCX82C200 will wait for six consecutive bits with identical polarity and when monitoring them, interpret them as an Error Flag. After transmission of an Error Flag, each PCX82C200 monitors the bus-line until it detects a transition from a dominant-to-recessive bit level. At this point in time, every PCX82C200 has finished transmitting its Error Flag and all PCX82C200's start transmitting seven additional recessive bits (Error Delimiter, see section 8.4.2). The message format of a Data Frame or Remote Frame is defined in such a way, that all detectable errors can be signalled within the message transmission time and therefore, it is very simple for a PCX82C200 to associate an Error Frame to the corresponding message and to initiate retransmission of the corrupted message. If a PCX82C200 monitors any deviation of the fixed form of an Error Frame, it transmits a new Error Frame. #### 8.7.5 OVERLOAD SIGNALLING Some CAN-controllers (but not the PCX82C200) require to delay the transmission of the next Data Frame or Remote Frame by transmitting one or more Overload Frames. The transmission of an Overload Frame must start during the first bit of an expected Intermission. Transmission of Overload Frames which are reactions on a dominant bit during an expected Intermission Field, start one bit after this event. Though the format of Overload Frame and Error Frame are identical, they are treated differently. Transmission of an Overload Frame during Intermission Field does not initiate the retransmission of any previous Data Frame or Remote Frame. If a CAN-controller which transmitted an Overload Frame monitors any deviation of its fixed form, it transmits an Error Frame. #### 8.8 Error detection The processes described in the following paragraphs are implemented in the PCX82C200 for error detection. #### 8.8.1 BIT ERROR A transmitting PCX82C200 monitors the bus on a bit-by-bit basis. If the bit level monitored is different from the transmitted one, a Bit Error is signalled. The exceptions being: - during the Arbitration Field, a recessive bit can be overwritten by a dominant bit. In this case, the PCX82C200 interprets this as a loss of arbitration - during the Acknowledge Slot, only the receiving PCX82C200's are able to recognize a Bit Error. #### 8.8.2 STUFF ERROR The following bit fields are coded using the bit-stuffing technique: - · Start-Of-Frame - · Arbitration Field - Control Field - Data Field - · CRC Sequence. There are two possible ways of generating a Stuff Error: - the disturbance generates more than the allowed five consecutive bits with identical polarity. These errors are detected by all PCX82C200's - a disturbance falsifies one or more of the five bits preceding the stuff bit. This error situation is not recognized as a Stuff Error by the receivers. Therefore, other error detection processes may detect this error condition such as: CRC check, format violation at the receiving PCX82C200's or Bit Error detection by the transmitting PCX82C200. 82C200 #### 8.8.3 CRC FRROR To ensure the validity of a transmitted message all receivers perform a CRC check. Therefore, in addition to the (destuffed) information digits (Start-Of-Frame up to Data Field), every message includes some control digits (CRC Sequence; generated by the transmitting PCX82C200 of the respective message) used for error detection. The code used for the PCX82C200 bus controller is a (shortened) BCH code, extended by a parity check and has the following attributes: - . 127 bits as maximum length of the code - 112 bits as maximum number of information digits (maximum 83 bits are used by PCX82C200) - · length of the CRC Sequence amounts to 15 bits - Hamming distance d = 6. As a result, (d-1) random errors are detectable (some exceptions exist). The CRC Sequence is calculated by the following procedure: - the destuffed bit stream consisting of Start-Of-Frame up to the Data Field (if present) is interpreted as a polynomial with coefficients of 0 or 1 - this polynomial is divided (modulo-2) by the following generator polynomial: $$f(X) = (X^{14} + X^9 + X^8 + X^6 + X^5 + X^4 + X^2 + X + 1)(X + 1)$$ = 11000101100110011 binary. The remainder of this polynomial division is the CRC Sequence which includes a parity check. Burst errors are detected up to a length of 15 [degree of f(X)]. Multiple errors (number of disturbed bits at least d=6) are not detected with a residual error probability of $2^{-15}$ (= $3 \times 10^{-5}$ ) by CRC check only. #### 8.8.4 FORM ERROR Form Errors result from violation of the fixed form of the following bit fields: - End-Of-Frame - Intermission - Acknowledge Delimiter - · CRC Delimiter. During the transmission of these bit fields an error condition is recognized if a dominant bit level instead of a recessive one is detected. #### 8.8.5 ACKNOWLEDGEMENT ERROR This is detected by a transmitter whenever it does not monitor a dominant bit during the Acknowledge Slot. 8.8.6 ERROR DETECTION BY AN ERROR FLAG OF ANOTHER PCX82C200 The detection of an error is signalled by transmitting an Error Flag. An Active Error Flag causes a Stuff Error, a Bit Error or a Form Error at all other PCX82C200's. #### 8.8.7 ERROR DETECTION CAPABILITIES Errors which occur at all PCX82C200's (global errors) are 100% detected. For local errors, i.e. for errors occurring at some PCX82C200's only, the shortened BCH code, extended by a parity check, has the following error detection capabilities: - up to five single bit errors are 100% detected, even if they are distributed randomly within the code - all single bit errors are detected if their total number (within the code) is odd - the residual error probability of the CRC check amounts to 3 x 10<sup>-5</sup>. As an error may be detected not only by CRC check but also by other detection processes described in sections 8.8.1 to 8.8.5, the residual error probability is several magnitudes less than 3 x 10<sup>-5</sup> for undetected errors. #### 8.9 Error confinement (definitions) #### 8.9.1 Bus-Off A PCX82C200 which has too many unsuccessful transmissions, relative to the number of successful transmissions, will enter the Bus-Off state. It remains in this state, neither receiving nor transmitting messages until the Reset Request bit is set LOW (absent) and both Error Counters are set to '0' (see note 1 to Table 5 and section 8.10.3). #### 8.9.2 ACKNOWLEDGE (ACK) A PCX82C200 which has received a valid message correctly, indicates this to the transmitter by transmitting a dominant bit level on the bus during the Acknowledge Slot, independent of accepting or rejecting the message. 82C200 #### 8.9.3 ERROR-ACTIVE An error-active PCX82C200 is in its normal operating state able to receive and to transmit normally and also to transmit an active Error Flag (see section 8.10.3). #### 8.9.4 ERROR-PASSIVE An error-passive PCX82C200 may transmit or receive messages normally. In the case of a detected error condition it transmits a Passive Error Flag, instead of an Active Error Flag. Hence the influence on bus activities by an error-passive PCX82C200 (e.g. due to a malfunction) is reduced. #### 8.9.5 SUSPEND TRANSMISSION After an error-passive PCX82C200 has transmitted a message, it sends eight recessive bits after the Intermission Field and then checks for Bus-Idle. If during Suspend Transmission another PCX82C200 starts transmitting a message the suspended PCX82C200 will become the receiver of this message; otherwise being in Bus-Idle it may start to transmit a further message. #### 8.9.6 START-UP A PCX82C200 which was either switched off or is in the Bus-Off state, must run a start-up routine in order to: - synchronize with other available PCX82C200's, before starting to transmit. Synchronizing is achieved, when 11 recessive bits, equivalent to Acknowledge Delimiter, End-Of-Frame and Intermission Field, have been detected (Bus-Free) - wait for other PCX82C200s without passing into the Bus-Off state (due to a missing acknowledge), if there is no other PCX82C200 currently available. #### 8.10 Aims of error confinement 8.10.1 DISTINCTION OF SHORT AND LONG-LASTING DISTURBANCES The microcontroller must be informed when there are long-lasting disturbances and when bus activities have returned to normal operation. During long-lasting disturbances, a PCX82C200 enters the Bus-Off state and the microcontroller may use default values. Minor disturbances of bus activities will not affect a PCX82C200. In particular, a PCX82C200 does not enter the Bus-Off state or inform the microcontroller of a short-lasting bus disturbance. # 8.10.2 DETECTION AND LOCALIZATION OF HARDWARE DISTURBANCES AND DEFECTS The rules for error confinement are defined by the CAN-protocol specification (and implemented in the PCX82C200), in that the PCX82C200, being nearest to the error-locus, reacts with a high probability, the quickest (i.e. becomes error-passive or Bus-Off). hence errors can be localized and their influence on normal bus activities is minimized. #### 8.10.3 ERROR CONFINEMENT All PCX82C200's contain a Transmit Error Counter and a Receive Error Counter, which registers errors during the transmission and the reception of messages, respectively. If a message is transmitted or received correctly, the count is decreased. In the event of an error, the count is increased. The Error Counters have an non-proportional method of counting: an error causes a larger counter increase than a correctly transmitted/received message causes the count to decrease. Over a period of time this may result in an increase in error counts, even if there are fewer corrupted messages than uncorrupted ones. The level of the Error Counters reflect the relative frequency of disturbances. The ratio of increase/decrease depends on the acceptable ratio of invalid/valid messages on the bus and is hardware implemented to eight. If one of the Error Counters exceeds the Warning Limit of 96 error points, indicating a significant accumulation of error conditions, this is signalled by the PCX82C200 (Error Status, Error Interrupt). A PCX82C200 operates in the error-active mode until it exceeds 127 error points on one of its Error Counters. At this point it will enter the error-passive state. A transmit error which exceeds 255 error points results in the PCX82C200 entering the Bus-Off state. 82C200 ## 9 LIMITING VALUES Limiting values in accordance with the Absolute Maximum Rating System (IEC134) | SYMBOL | PARAMETER | MIN. | MAX. | UNIT | |------------------|---------------------------------------------------------|-------|------|------| | V <sub>DD</sub> | supply voltage range | 4.5 | 5.5 | V | | l, | input/output current on any pin except from TX0 and TX1 | - "," | ±10 | mA | | l <sub>ot</sub> | sink current of TX0 and TX1 together (note 1) | | 28 | mA | | l <sub>ot</sub> | source current of TX0 and TX1 together (note 1) | | -20 | mA | | T <sub>amb</sub> | operating ambient temperature range:<br>PCA82C200 | -40 | +125 | °C | | | PCF82C200 | -40 | +85 | °C | | T <sub>stg</sub> | storage temperature range | -65 | +150 | °C | | P <sub>tot</sub> | total power dissipation (note 2) | - 26 | 1 | W | ## Notes - I<sub>OT</sub> is allowed in case of a bus failure condition because then the TX-outputs are switched off automatically after a short time (Bus-Off state). During normal operation I<sub>OT</sub> is a peak current, permitted for t < 100 ms. The average output current must not exceed 10 mA for each TX-output. - 2. The value is based on the maximum allowable die temperature and the thermal resistance of the package, not on device power consumption. ## 10 DC CHARACTERISTICS $V_{DD} \le 5~V~\pm 10\%; V_{SS} = 0~V; T_{amb} = -40~to~+125~^{\circ}C~for~the~PCA82C200~and~T_{amb} = -40~to~+85~^{\circ}C~for~the~PCF82C200.$ All voltages measured with respect to $V_{ss}$ unless otherwise specified | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------|---------------------------------------|------| | Supply | Marin National Control of the Contro | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | V <sub>DD</sub> | supply voltage range | | 4.5 ⊶ | 5.5 | V | | I <sub>DD</sub> | supply current:<br>operating | $\overline{RST} = V_{SS};$ $f_{CLK} = 16 \text{ MHz (note 1)}$ | - | 15 | mA | | l <sub>sm</sub> | sleep mode | oscillator inactive (note 2) | | 40 | μА | | Inputs | | | | | | | V <sub>IL1</sub> | LOW level input voltage<br>(except XTAL1, RX0 and RX1) | | -0.5 | 0.8 | V | | V <sub>IL2</sub> | XTAL1 LOW level input voltage | | - | 0.2V <sub>DD</sub> | V | | V <sub>IH1</sub> | HIGH level input voltage (except XTAL1, RST, RX0 and RX1) | | 3.2 | V <sub>DD</sub> + 0.5 | V | | V <sub>IH2</sub> | XTAL1 HIGH level input voltage | | 0.7V <sub>DD</sub> | - ° ° | V | | V <sub>IH3</sub> | RST HIGH level input voltage | | 3.3 | $V_{DD} + 0.5$ | V | | l <sub>u</sub> | input leakage current<br>(except XTAL1, RX0 and RX1) | 0.45 V < V <sub>1</sub> < V <sub>DD</sub> | - | ±10 | μА | November 1992 395 # Stand-alone CAN-controller 82C200 | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |-------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------------|---------| | Outputs | | 10 (10 ) 10 (14 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 (15 ) 10 | | | | | V <sub>OL</sub> | LOW level output voltage (except XTAL2, TX0 and TX1) | I <sub>OL</sub> = 1.6 mA | - | 0.45 | ٧ | | V <sub>OH1</sub> | HIGH level output voltage (except TX0, TX1, INT and CLK OUT) | I <sub>OH</sub> = -80 μA | 2.4 | | V | | V <sub>OH2</sub> | CLK OUT HIGH level output voltage | I <sub>OH</sub> = -80 μA | 0.8V <sub>DD</sub> | | ٧ | | CAN input | comparator | | | | | | | | $V_{DD} = 5 \text{ V } \pm 5\%;$<br>1.4 V < V <sub>1</sub> < V <sub>DD</sub> - 1.4 V | 100 | | | | V <sub>DIF</sub> | differential input voltage | note 3 | ±42 | | mV | | V <sub>HYST</sub> | hysteresis voltage | note 3 | 12 | 45 | mV . | | l <sub>i</sub> . | input current | | _ " | ±400 | nA | | CAN outp | ut driver | | | | 3 747.5 | | | | V <sub>DD</sub> = 5 V ±5% | | 10 | | | Volt | TX0 and TX1 output voltage LOW | l <sub>o</sub> = 1.2 mA (note 3) | - | 0.1 | V | | | The state of the state of the state of | I <sub>o</sub> = 10 mA | <b>-</b> | 1.0 | V | | V <sub>OHT</sub> | TX0 and TX1 output voltage HIGH | I <sub>o</sub> = 1.2 mA (note 3) | V <sub>DD</sub> - 0.1 | <b>-</b> c 9700 | V. | | | | I <sub>o</sub> = 10 mA | V <sub>DD</sub> - 1.0 | - | V | #### Notes - 1. $(ADO-AD7) = ALE = \overline{RD} = \overline{WR} = \overline{CS} = V_{DD}$ ; $MODE = V_{SS}$ ; RX0 = 2.7 V; RX1 = 2.3 V; XTAL1 = 0.5 V/ $V_{DD} = 0.5$ V; all outputs unloaded. - 2. (AD0 AD7) = ALE = $\overline{\text{RD}}$ = $\overline{\text{WR}}$ = $\overline{\text{INT}}$ = $\overline{\text{RST}}$ = $\overline{\text{CS}}$ = MODE = RX0 = V<sub>DD</sub>; RX1 = XTAL1 = V<sub>SS</sub>; all outputs unloaded. - 3. Not tested during production. November 1992 396 # Stand-alone CAN-controller 82C200 11 AC CHARACTERISTICS $V_{DD}$ = 5 V ±10%; $V_{SS}$ = 0 V; $C_L$ = 50 pF (output pins); $T_{amb}$ = -40 to +85/125 °C; unless otherwise specified (note 1) | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |-------------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------|------| | f <sub>CLK</sub> | oscillator frequency | | 3 | 16 | MHz | | t <sub>su1</sub> | address set-up to ALE/AS LOW | | 10 | - | ns | | t <sub>HD1</sub> | address hold time | | 22 | 1- | ns | | t <sub>PW1</sub> | ALE/AS pulse width | | 35 | - | ns | | t <sub>VD1</sub> | RD LOW to valid data output | Intel mode | - " " | 60 | ns | | t <sub>VD2</sub> | E HIGH to valid data output | Motorola mode | - | 60 | ns | | t <sub>DF1</sub> | data float after RD HIGH | Intel mode | 10 | 55 | ns | | t <sub>DF2</sub> | data float after E LOW | Motorola mode | 10 | 55 | ns | | t <sub>SU2</sub> | input data set-up to WR HIGH | Intel mode | 30 | - | ns | | t <sub>HD2</sub> | input data hold after WR HIGH | Intel mode | 13 | - | ns | | <b>t</b> <sub>HH1</sub> | WR HIGH to next ALE HIGH | The second secon | 23 | - 1 | ns | | t <sub>LH3</sub> | E LOW to next AS HIGH | Motorola mode | 23 | - | ns | | t <sub>sua</sub> | input data set-up to E LOW | Motorola mode | 30 | - | ns | | t <sub>HD3</sub> | input data hold after E LOW | Motorola mode | 25 | 1- | ns | | t <sub>LL1</sub> | ALE LOW to WR LOW | Intel mode | 10 | - | ns | | t <sub>LL2</sub> | ALE LOW to RD LOW | Intel mode | 10 | - | ns | | t <sub>LH1</sub> | AS LOW to E HIGH | Motorola mode | 10 | - | ns | | t <sub>SU4</sub> | set-up time of RD/WR to E HIGH | Motorola mode | 20 | - | ns | | t <sub>PW2</sub> | WR pulse width | Intel mode | 170 | 1- | ns | | t <sub>PW3</sub> | RD pulse width | Intel mode | 170 | 1- | ns | | t <sub>PW4</sub> | E pulse width | Motorola mode | 170 | 1- | ns | | t <sub>LL3</sub> | CS LOW to WR LOW | Intel mode | 0 | - | ns | | t <sub>LL4</sub> | CS LOW to RD LOW | Intel mode | 0 | 1- | ns | | t <sub>LH2</sub> | CS LOW to E HIGH | Motorola mode | 0 | - | ns | | Input compa | arator/output driver | | -1 | <del></del> | | | t <sub>sd</sub> | sum of the input and output delays | $V_{DD} = 5 \text{ V} \pm 5\%;$<br>$V_{DIF} = \pm 42 \text{ mV};$<br>$1.4 \text{ V} < V_{I} < V_{DD} - 1.4 \text{ mV}$ | = | 62 | ns | ## Note 1. AC characteristics are not tested. November 1992 397 ## 11.1 AC timing diagrams 398 November 1992 ## Stand-alone CAN-controller 82C200 #### 11.2 Additional AC information To provide optimum noise immunity under worse case conditions, the chip is powered by three separate pins and grounded by three separate pins, see Fig.12. Fig.12 Optimized noise immunity block diagram. ## 12 DEVELOPMENT SUPPORT AND TOOLS #### 12.1 The PCX82C200 Evaluation Board Philips offers powerful support during the design and test stages of CAN networks, working closely with customers to develop their systems. The 'Philips Stand-alone CAN-Controller (PSCC) Evaluation Board' is a versatile tool being a ready-to-use hardware and software module, very similar to a real CAN module. Since a 5 V power supply is provided, the board can be used in any vehicle without modification. An RS232 interface allows a terminal or a PC with terminal-emulation software to be connected to the board. The board comprises: - a PCX82C200 CAN-bus controller - a PCA80C552 microcontroller with up to 32K x 8 bits external RAM and EPROM - a 5 V power supply with protection against car battery disturbances - two different physical CAN-bus interfaces (selectable) - an RS232 interface - · demonstration hardware - · a wrap field for customer-specific circuitry. The software provided with the board supports "learning about CAN" and assists in prototype (e.g. in-vehicle) networks. It provides: - · demonstration software (automatically-initiated) - the menu-driven software comprises: - a facility to alter the contents of the PCX82C200 registers - a bus monitor to receive messages from the CAN-bus and to display them on a terminal - a download facility for the user's application software. With these facilities the board is a basis for prototype modules; when using entirely your own software, the board can be used as a custom, debugged and proven hardware module. #### 12.2 Advanced support For further development support, Philips subcontractor I+ME offers a complete set of development tools including: - a CAN simulator; CAN/Net Sim - · an emulator; CAN/Net Emu - · a network analyzer; CAN/Net Anal. I+ME can be contacted through the following address: I+ME GmbH Ferdinandstrasse 15 A D-3340 Wolfenbuettel West Germany. Phone: ++49-5331-72066 Fax: ++49-5331-32455 ## PCA82C250 ## **FEATURES** - Fully compatible with the "ISO/DIS 11898" standard - · High speed (up to 1 Mbaud) - Bus lines protected against transients in an automotive environment - Slope control to reduce radio frequency interference (RFI) - Differential receiver with wide common-mode range for high immunity against electromagnetic interference (EMI) - · Thermally protected - · Short-circuit proof to battery and ground - · Low current standby mode - · An unpowered node does not disturb the bus lines - · At least 110 nodes can be connected. ## **APPLICATIONS** · High-speed applications (up to 1 Mbaud) in cars. ## **GENERAL DESCRIPTION** The PCA82C250 is the interface between the CAN protocol controller and the physical bus. The device provides differential transmit capability to the bus and differential receive capability to the CAN controller. ## QUICK REFERENCE DATA | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |--------------------|---------------------------------|--------------------|------|------|-------| | V <sub>CC</sub> | supply voltage | | 4.5 | 5.5 | V | | Icc | supply current | | _ | 170 | μΑ | | 1/t <sub>bit</sub> | maximum transmission speed | non-return-to-zero | 1 | - | Mbaud | | V <sub>CAN</sub> | CANH, CANL input/output voltage | | -8 | +18 | V | | ΔV | differential bus voltage | | 1.5 | 3.0 | ٧ | | t <sub>pd</sub> | propagation delay | high-speed mode | _ | 50 | ns | | T <sub>amb</sub> | operating ambient temperature | | -40 | +125 | °C | ## ORDERING INFORMATION | TVDF 111110FD | | PACK | AGE | | |---------------|------|--------------|----------|---------| | TYPE NUMBER | PINS | PIN POSITION | MATERIAL | CODE | | PCA82C250 | 8 | DIP8 | plastic | SOT97-1 | | PCA82C250T | 8 | SO8 | plastic | SOT96-1 | # PCA82C250 ## **BLOCK DIAGRAM** ## **PINNING** | SYMBOL | PIN | DESCRIPTION | |------------------|-----|-------------------------------------| | TxD | 1 | transmit data input | | GND | 2 | ground | | V <sub>CC</sub> | 3 | supply voltage | | RxD | 4 | receive data output | | V <sub>ref</sub> | 5 | reference voltage output | | CANL | 6 | LOW level CAN voltage input/output | | CANH | 7 | HIGH level CAN voltage input/output | | Rs | 8 | slope resistor input | ## PCA82C250 #### **FUNCTIONAL DESCRIPTION** The PCA82C250 is the interface between the CAN protocol controller and the physical bus. It is primarily intended for high-speed applications (up to 1 Mbaud) in cars. The device provides differential transmit capability to the bus and differential receive capability to the CAN controller. It is fully compatible with the "ISO/DIS 11898" standard. A current limiting circuit protects the transmitter output stage against short-circuit to positive and negative battery voltage. Although the power dissipation is increased during this fault condition, this feature will prevent destruction of the transmitter output stage. If the junction temperature exceeds a value of approximately 160 °C, the limiting current of both transmitter outputs is decreased. Because the transmitter is responsible for the major part of the power dissipation, this will result in a reduced power dissipation and hence a lower chip temperature. All other parts of the IC will remain in operation. The thermal protection is particularly needed when a bus line is short-circuited. The CANH and CANL lines are also protected against electrical transients which may occur in an automotive environment. Pin 8 (Rs) allows three different modes of operation to be selected: high-speed, slope control or standby. For high-speed operation, the transmitter output transistors are simply switched on and off as fast as possible. In this mode, no measures are taken to limit the rise and fall slope. Use of a shielded cable is recommended to avoid RFI problems. The high-speed mode is selected by connecting pin 8 to ground. For lower speeds or shorter bus length, an unshielded twisted pair or a parallel pair of wires can be used for the bus. To reduce RFI, the rise and fall slope should be limited. The rise and fall slope can be programmed with a resistor connected from pin 8 to ground. The slope is proportional to the current output at pin 8. If a HIGH level is applied to pin 8, the circuit enters a low current standby mode. In this mode, the transmitter is switched off and the receiver is switched to a low current. If dominant bits are detected (differential bus voltage >0.9 V), RxD will be switched to a LOW level. The microcontroller should react to this condition by switching the transceiver back to normal operation (via pin 8). Because the receiver is slow in standby mode, the first message will be lost. Table 1 Truth table of CAN transceiver. | SUPPLY | TxD | CANH | CANL | BUS STATE | RxD | |-------------------------------|----------------------|-----------------------|-----------------------|-----------|-----| | 4.5 to 5.5 V | 0 | HIGH | LOW | dominant | 0 | | 4.5 to 5.5 V | 1 (or floating) | floating | floating | recessive | 1 | | <2 V (not powered) | X | floating | floating | recessive | X | | 2 V < V <sub>CC</sub> < 4.5 V | >0.75V <sub>CC</sub> | floating | floating | recessive | X | | 2 V < V <sub>CC</sub> < 4.5 V | Х | floating if | floating if | recessive | Х | | | | $V_{Rs} > 0.75V_{CC}$ | $V_{Rs} > 0.75V_{CC}$ | | | Table 2 Rs (pin 8) summary. | CONDITION FORCED AT Rs | MODE | RESULTING VOLTAGE OR<br>CURRENT AT Rs | |---------------------------------------|---------------|-----------------------------------------------------------| | V <sub>Rs</sub> > 0.75V <sub>CC</sub> | standby | I <sub>Rs</sub> < I10 μAI | | –10 μA < I <sub>Rs</sub> < –200 μA | slope control | 0.4V <sub>CC</sub> < V <sub>Rs</sub> < 0.6V <sub>CC</sub> | | V <sub>Rs</sub> < 0.3V <sub>CC</sub> | high-speed | I <sub>Rs</sub> < -500 μA | 403 PCA82C250 ## **LIMITING VALUES** In accordance with the Absolute Maximum Rating System (IEC 134). All voltages are referenced to pin 2; positive input current. | SYMBOL | PARAMETER | CONDITIONS | MIN. | MAX. | UNIT | |------------------|-----------------------------------|-------------------------------------------------|------|-----------------------|------| | V <sub>CC</sub> | supply voltage | | -0.3 | +9.0 | ٧ | | Vn | DC voltage at pins 1, 4, 5 and 8 | | -0.3 | V <sub>CC</sub> + 0.3 | ٧ | | V <sub>6,7</sub> | DC voltage at pins 6 and 7 | 0 V < V <sub>CC</sub> < 5.5 V;<br>no time limit | -8.0 | +18.0 | V | | V <sub>trt</sub> | transient voltage at pins 6 and 7 | see Fig.8 | -150 | +100 | V | | T <sub>stg</sub> | storage temperature | Tall tall to the fill | -55 | +150 | °C | | T <sub>amb</sub> | operating ambient temperature | 14 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | -40 | +125 | °C | | T <sub>vj</sub> | virtual junction temperature | note 1 | -40 | +150 | °C | ## Note 1. In accordance with "IEC 747-1". An alternative definition of virtual junction temperature $T_{vj}$ is: $T_{vj} = T_{amb} + P_d \times P_{th vj-amb}$ , where $P_{th vj-amb}$ is a fixed value to be used for the calculation of $T_{vj}$ . The rating for $T_{vj}$ limits the allowable combinations of power dissipation ( $P_d$ ) and ambient temperature ( $T_{amb}$ ). ## **HANDLING** Classification A: human body model; C = 100 pF; R = 1500 $\Omega$ ; V = $\pm 2000$ V. Classification B: machine model; C = 200 pF; $R = 0 \Omega$ ; $V = \pm 200 \text{ V}$ . ## **QUALITY SPECIFICATION** Quality specification "SNW-FQ-611 part E" is applicable and can be found in the "Quality reference pocket-book" (ordering number 9398 510 34011). ## THERMAL CHARACTERISTICS | SYMBOL | PARAMETER | VALUE | UNIT | |---------------------|---------------------------------------------------------|-------|------| | R <sub>th j-a</sub> | thermal resistance from junction to ambient in free air | | | | • | PCA82C250 | 100 | K/W | | | PCA82C250T | 160 | k/W | # PCA82C250 ## **CHARACTERISTICS** $V_{CC}$ = 4.5 to 5.5 V; $T_{amb}$ = -40 to +125 °C; $R_L$ = 60 $\Omega$ ; $I_8$ > -10 $\mu$ A; unless otherwise specified. All voltages referenced to ground (pin 2); positive input current; all parameters are guaranteed over the ambient temperature range by design, but only 100% tested at +25 °C. | SYMBOL | PARAMETER | CONDITIONS | MIN. | TYP. | MAX. | UNIT | |------------------------|------------------------------------------------------|-----------------------------------------------------------------------|--------------------------|------------|------------------------------------------------|-------| | Supply | | | | | | | | l <sub>3</sub> | supply current | dominant; V <sub>1</sub> = 1 V | T- | T- | 70 | mA | | | | recessive; $V_1 = 4 V$ ; $R_8 = 47 \text{ k}\Omega$ | - | - | 14 | mA | | | | recessive; V <sub>1</sub> = 4 V;<br>V <sub>8</sub> = 1 V | - | | 18 | mA | | | | standby; T <sub>amb</sub> < 90 °C;<br>note 1 | | 100 | 170 | μА | | DC bus transi | mitter | | | | | | | V <sub>IH</sub> | HIGH level input voltage | output recessive | 0.7V <sub>CC</sub> | <b>I</b> - | V <sub>CC</sub> + 0.3 | V | | V <sub>IL</sub> | LOW level input voltage | output dominant | -0.3 | - | 0.3V <sub>CC</sub> | V | | I <sub>IH</sub> | HIGH level input current | V <sub>1</sub> = 4 V | -200 | - | +30 | μА | | I <sub>IL</sub> | LOW level input voltage | V <sub>1</sub> = 1 V | 100 | - | 600 | μА | | V <sub>6,7</sub> | recessive bus voltage | V <sub>1</sub> = 4 V; no load | 2.0 | _ | 3.0 | V | | I <sub>LO</sub> | off-state output leakage current | $-2 \text{ V} < (\text{V}_{6}, \text{V}_{7}) < 7 \text{ V}$ | -2 | _ | +1 | mA | | | | -5 V < (V <sub>6</sub> ,V <sub>7</sub> ) < 18 V | <b>-</b> 5 | ı— " | +12 | mA | | V <sub>7</sub> | CANH output voltage | V <sub>1</sub> = 1 V | 2.75 | _ | 4.5 | V | | V <sub>6</sub> | CANL output voltage | V <sub>1</sub> = 1 V | 0.5 | - | 2.25 | V | | ΔV <sub>6,7</sub> | difference between output<br>voltage at pins 6 and 7 | V <sub>1</sub> = 1 V | 1.5 | - | 3.0 | V | | | | $V_1 = 1 \text{ V}; R_L = 45 \Omega; V_{CC} \ge 4.9 \text{ V}$ | 1.5 | | 1 <u>1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1</u> | V | | | | V <sub>1</sub> = 4 V; no load | -500 | | +50 | mV | | I <sub>sc7</sub> | short-circuit CANH current | $V_7 = -5 \text{ V}; V_{CC} \le 5 \text{ V}$ | - | - | 105 | mA | | | | $V_7 = -5 \text{ V}; V_{CC} = 5.5 \text{ V}$ | _ *** | _ | 120 | mA | | I <sub>sc6</sub> | short-circuit CANL current | V <sub>6</sub> = 18 V | _ | | 160 | mA | | DC bus receiv | ver: V <sub>1</sub> = 4 V; pins 6 and 7 externa | ally driven; –2 V < (V <sub>6,</sub> V | <sub>7</sub> ) < 7 V; uı | nless othe | rwise spec | ified | | V <sub>diff(r)</sub> | differential input voltage | T | -1.0 | T- | 0.5 | Īv | | | (recessive) | -7 V < (V <sub>6</sub> , V <sub>7</sub> ) < 12 V;<br>not standby mode | -1.0 | - | 0.4 | V | | V <sub>diff(d)</sub> | differential input voltage | | 0.9 | 1- | 5.0 | V | | | (dominant) | -7 V < (V <sub>6</sub> , V <sub>7</sub> ) < 12 V;<br>not standby mode | 1.0 | - | 5.0 | V | | V <sub>diff(hys)</sub> | differential input hysteresis | see Fig.5 | 1- | 150 | 1 | mV. | | V <sub>OH</sub> | HIGH level output voltage (pin 4) | Ι <sub>4</sub> = -100 μΑ | 0.8V <sub>CC</sub> | - | V <sub>CC</sub> | V | | V <sub>OL</sub> | LOW level output voltage | I <sub>4</sub> = 1 mA | 0 | _ | 0.2V <sub>CC</sub> | V | | | (pin 4) | I <sub>4</sub> = 10 mA | 0 | - | 1.5 | V | | Ri | CANH, CANL input resistance | | 5 | 1- | 25 | kΩ | September 1994 405 # PCA82C250 | SYMBOL | PARAMETER | CONDITIONS | MIN. | TYP. | MAX. | UNIT | |---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------|---------------------|------| | R <sub>diff</sub> | differential input resistance | | 20 | _ | 100 | kΩ | | Ci | CANH, CANL input capacitance | | | - | 20 | pF | | C <sub>diff</sub> | differential input capacitance | and the second s | | - | 10 | pF | | Reference out | put | | | | | | | V <sub>ref</sub> | reference output voltage | V <sub>8</sub> = 1 V;<br>-50 μA < I <sub>5</sub> < 50 μA | 0.45V <sub>CC</sub> | . <del>-</del> , | 0.55V <sub>CC</sub> | V | | | | V <sub>8</sub> = 4 V;<br>-5 μA < I <sub>5</sub> < 5 μA | 0.4V <sub>CC</sub> | - | 0.6V <sub>CC</sub> | ٧ | | Timing (see Fi | igs 4, 6 and 7) | | | | | | | t <sub>bit</sub> | minimum bit time | V <sub>8</sub> = 1 V | _ | _ | 1 | μs | | t <sub>onTxD</sub> | delay TxD to bus active | V <sub>8</sub> = 1 V | _ | - | 50 | ns | | t <sub>offTxD</sub> | delay TxD to bus inactive | V <sub>8</sub> = 1 V | - | 40 | 80 | ns | | tonRxD | delay TxD to receiver active | V <sub>8</sub> = 1 V | <del>-</del> | 55 | 120 | ns | | t <sub>offRxD</sub> | delay TxD to receiver inactive | V <sub>8</sub> = 1 V; V <sub>CC</sub> < 5.1 V;<br>T <sub>amb</sub> < +85 °C | | 82 | 150 | ns | | | | V <sub>8</sub> = 1 V; V <sub>CC</sub> < 5.1 V;<br>T <sub>amb</sub> < +125 °C | | 82 | 170 | ns | | | | V <sub>8</sub> = 1 V; V <sub>CC</sub> < 5.5 V;<br>T <sub>amb</sub> < +85 °C | _3.98 1 99 .<br>- 1.00 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 90 | 170 | ns | | | | V <sub>8</sub> = 1 V; V <sub>CC</sub> < 5.5 V;<br>T <sub>amb</sub> < +125 °C | _ | 90 | 190 | ns | | t <sub>onRxD</sub> | delay TxD to receiver active | $R_8 = 47 \text{ k}\Omega$ | - | 390 | 520 | ns | | | and the state of t | $R_8 = 24 \text{ k}\Omega$ | - | 260 | 320 | ns | | t <sub>offRxD</sub> | delay TxD to receiver inactive | $R_8 = 47 \text{ k}\Omega$ | | 260 | 450 | ns | | | | $R_8 = 24 \text{ k}\Omega$ | _ | 210 | 320 | ns | | ISRI | differential output voltage slew rate | $R_8 = 47 \text{ k}\Omega$ | - | 14 | - | V/µs | | twake | wake-up time from standby (via pin 8) | | - | _ | 20 | μs | | t <sub>dRxDL</sub> | bus dominant to RxD LOW | V <sub>8</sub> = 4 V; standby mode | - | | 3 | μs | | Standby/slop | e control (pin 8) | The second secon | | | | | | V <sub>8</sub> | input voltage for high-speed | | T- | - , | 0.3V <sub>CC</sub> | V | | I <sub>8</sub> | input current for high-speed | V <sub>8</sub> = 0 V | _ | - | -500 | μА | | V <sub>stb</sub> | input voltage for standby mode | | 0.75V <sub>CC</sub> | - , | - | V | | I <sub>slope</sub> | slope control mode current | | -10 | - | -200 | μΑ | | V <sub>slope</sub> | slope control mode voltage | euro e November | 0.4V <sub>CC</sub> | _ | 0.6V <sub>CC</sub> | V | ## Note 1. $I_1 = I_4 = I_5 = 0$ mA; $0 \text{ V} < V_6 < V_{CC}$ ; $0 \text{ V} < V_7 < V_{CC}$ ; $V_8 = V_{CC}$ . # PCA82C250 ## **APPLICATION INFORMATION** # PCA82C250 ## INTERNAL PIN CONFIGURATION # **Philips Semiconductors** # **Section 7** 87C750, 8XC751, 8XC752 Application Notes Application Notes and Development Tools for 80C51 Microcontrollers ## CONTENTS | AN422 | Using the 8XC751 microcontroller as an I $^2\text{C}$ bus master $\hdots$ . See Section | |------------|----------------------------------------------------------------------------------------------------------| | AN423 | Software driven serial communication routines for the 83C751 and 83C752 microcontrollers | | AN426 | Controlling air core meters with the 87C751 and SA5775 | | AN427 | Timer I for the 83/87C748/749 and the 83/87C751/752 (non-I <sup>2</sup> C applications) microcontrollers | | AN428 | Using the ADC and PWM of the 83C752/87C752 | | AN429 | Airflow measurement using the 83/87C752 and "C" | | AN430 | Using the 8XC751/752 in multimaster I $^2$ C applications See Section | | AN433 | I <sup>2</sup> C slave routines for the 83C751 See Section | | AN436 | "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller | | AN439 | 87C751 fast NiCad charger | | AN442 | (BCM) 87C751 Specification for a bus-controlled monitor | | AN445 | ACCESS.bus mouse application code for the 8XC751 microcontroller 50 | | AN446 | A software duplex UART for the 751/752 53 | | AN453 | Using the 87C751 microcontroller to gang program PCF8582/PCF8581 EEPROMs | | AN454 | Interfacing the 83C576/87C576 to the ISA bus | | EIE/AN9100 | 7 I <sup>2</sup> C driver routines for 8XC751/2 microcontrollers See Section | Philips Semiconductors Application note # Software driven serial communication routines for the 83C751 and 83C752 microcontrollers **AN423** ## DESCRIPTION The need often arises to make use of a serial port in connection with a microcontroller that does not have a hardware UART on-chip. Aside from the obvious cases where the microcontroller application intrinsically requires RS-232 communications to achieve its purpose, a serial output may often be a simple and convenient method of providing detailed diagnostic information to the outside world while using only a single I/O port pin. In many cases, the solution may be to implement the UART function in software. The routines included here demonstrate a method to add such a function to a microcontroller without the benefit of a hardware UART. Examples of microcontrollers that do not have on-chip UARTs are the 83C751 and 83C752. While it is possible to connect an external UART chip to these microcontrollers, it tends to use up many I/O port pins and begins to become less economical than simply using a standard 80C51. The are several factors to be considered in deciding if the software UART method will be usable in a particular application. The first is whether the serial communication channel is to be simplex (transmit only or receive only), half-duplex (transmit and receive, but not simultaneously), or full-duplex (simultaneous transmit and receive). Both simplex and half-duplex operation are fairly easy to implement in software on an 80C51-type microcontroller, and will be covered by this application note. Full-duplex operation is more difficult to implement in software and can use up a large portion of the microcontroller's time and resources. A second consideration to be taken into account is the amount of system resources that will be "used up" by the serial communication software. First of all, such software routines will almost always require the use of at least one counter/timer to generate the time slices for the serial bit cells. Next, the physical connection to the outside world will require one I/O port pin each for the serial input and the serial output. Moreover. the port pin used for serial input should be an external interrupt input pin. This allows the software to be interrupted automatically at the beginning of an incoming start bit and synchronizes the timer accurately to the serial data stream. Additional port pins may be used to implement signals such as Request to Send (RTS), Clear to Send (CTS), etc. Finally, serial communication software will take up a certain amount of CPU time, more than would be required to operate a hardware UART. The overhead of software implemented serial communication may or may not be an issue, depending on the application, the throughput of the serial channel(s), the baud rate, other tasks the CPU is handling and how time-critical they are, etc. The program listing that is included here is a demonstration of half-duplex serial routines on the 83C751 or 83C752 microcontrollers. The operation of the software would be the same on other 80C51 derivatives, except that the counter/timer operation is slightly different. The program, as listed, will send a canned message to the serial output (port pin P1.0 in this case), then wait for data on the serial input (port pin P1.5/INT0). When a character has been received on the serial input, it will be echoed through the serial output. Since the software is inherently half-duplex, the rate at which characters are received must be less than half the rate that would be possible on a full-duplex channel. This example has been set up to receive and transmit at 9600 baud when run with a 16 MHz crystal. The operation of the routines is fairly straightforward. Beginning with a start bit occurring on the serial input line, an interrupt (external interrupt 0) will occur. At the interrupt service routine Int0, the counter/timer is loaded with a value that will result in a time delay that is approximately equivalent to half a bit cell time for the baud rate being used, less some constant to account for the elapsed time between a timer interrupt and the point where the serial input is actually sampled. The timer reload register is loaded with a value that will result in a time delay that is as close as can be calculated to one full bit cell time. The program then starts the timer and simply returns to the main program, waiting for the timer to time out, generating another interrupt. At that point, the serial start bit should be about halfway through its nominal duration. When the first timer interrupt occurs, the timer interrupt routine Timr0 calls the receive bit routine RxBit which checks to make sure that the start bit is still valid and flags an error if it is not. The RxBit routine will then return control to the main program routine, waiting for the next timer interrupt. On the second timer interrupt, the RxBit routine reads the serial input line and shifts the value into the serial holding register RxDat. This process is repeated until 8 bits have been read in on consecutive timer interrupts. Finally, on the tenth timer interrupt, the receive routine looks for a valid stop bit and flags an error if one is not detected. At this point, the RcvRdy flag is set to inform the main program that a character is waiting in the holding register. The transmit routine works in a somewhat similar fashion, beginning with a call to the byte transmit routine XmtByte, which first checks to make sure that a byte receive operation is not already in progress. The RSXmt routine will then set up the timer and timer reload registers to correspond to one bit cell time, start the timer, and assert a start bit. At each subsequent timer interrupt, the routine TxBit shifts out the next bit from the transmit holding register XmtDat, until all 8 bits have been transmitted. Once all of the data has been sent, the stop bit is asserted on the next timer interrupt. A final timer interrupt is required to insure that the stop bit lasts at least one full bit cell time. At this point, transmit flag TxFlag is cleared in order to inform the main program that the transmission is completed. Different baud rates and different crystal frequencies can be handled easily by simply changing the values in the program for BaudVal and StrtVal. BaudVal is simply the number of 8xC751 machine cycles that occur during one bit call time in the serial transmission. So, it may be calculated as the crystal frequency /12, divided by the baud rate. This number is rounded to the nearest integer and expressed as a negative number in the code. For example, the value shown in the listing is for 9600 baud with a 16MHz crystal. 16 million divided by 12, divided by 9600 = 138.8889. This is stated in the program as –139. StrtVal is used to position the sampling of the serial input during a receive operation to the approximate middle of the bit cell. This is nominally half the value of BaudVal, minus some overhead to account for the interrupt latency, plus the time it takes to get to the instruction that actually reads the input. StrtVal may be calculated as BaudVal / 2 + 30. For example, using the BaudVal value from the listing: -139 / 2 + 30 = -39. A few other useful routines are embedded in the sample program: PrByte, which converts a byte of data to hexadecimal form and transmits it; HexAsc, which converts one nibble of raw data to hexadecimal form; and Mess, which transmits an absolute string of data (usually a text message) which is terminated by a 0 byte. This demonstration of software driven serial port routines uses 5 bytes of microcontroller RAM, two port bits (including one external interrupt input), one counter/timer, and about 256 bytes of code space, excluding the message string at the end of the listing. November 1989 415 AN423 | RS751 Hal | f-Duple | x Serial | Communicat | ion Routines | 11/14/89 | |---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 2 | ; ***** | ****** | ***** | ****** | | | 3<br>4 | | Coftwaro | Drivon Walf-Dunley | Serial Communication Routines | | | 5 | . <b>.</b> | | | series Microcontrollers | | | 6 | ; | 101 | . 63C/31 and 63C/32 | Series Microconcrotters | | | 7 | | | | | | | | ; | | | | | | 8 | | | | ******** | | | 9 | , | | | | | | 10 | ¢m; +1 - (1) | alf Dumlas | . Comial Communicat | ion Boutines) | | | 11 | | | Serial Communicat | ion Routines) | | | 12 | \$Date(11 | /14/89) | | | | | 13 | \$MOD751 | | | | | | 14 | | | | ********* | | | 15 | , | | | | | 7775 | 16 | n | TOTA | 120 | m/ | | FF75 | 17 | BaudVal | EQU . | -139 | ;Timer value for 9600 baud @ 16 MHz. | | | 18 | G | DOM | 20 | ; (one bit cell time) | | FFD9 | 19 | StrtVal | EQU | -39 | ;Timer value to start receive. | | | 20 | | | | ; (half of one bit cell time, minus the | | | 21 | | | | ; time it takes the code to sample RxD) | | 0010 | 22 | V | D3.003 | 101- | P-t- f pg 222 tt- | | 0010 | 23 | XmtDat | DATA | 10h | ;Data for RS-232 transmit routine. | | 0011 | 24 | RcvDat | DATA | 11h | ;Data from RS-232 receive routine. | | 0012 | 25 | BitCnt | DATA | 12h | ;RS-232 transmit & receive bit count. | | 0013 | 26 | LoopCnt | DA'I'A | 13h | ;Loop counter for test routine. | | | 27 | | | | | | 0020 | 28 | Flags | DATA | 20h | | | 0000 | 29 | TxFlag | BIT | Flags.0 | ;Receive-in-progress flag. | | 0001 | 30 | RxFlag | BIT | Flags.1 | :Transmit-in-progress flag. | | 0002 | 31 | RxErr | BIT | Flags.2 | Receiver framing error. | | 0003 | 3.2 | RcvRdy | BIT | Flags.3 | ;Receiver ready flag. | | | 33 | | | | | | 0090 | 34 | TxD | BIT | P1.0 | ; Port bit for RS-232 transmit. | | 0095 | 35 | RxD | BIT | P1.5 | ;Port bit for RS-232 receive (INTO). | | | 36 | | وتوعون فالمراج بوالمراج | | ********* | | | 37 | ; * * * * * * * | | ****** | **** | | | 38<br>39 | T | *** | | | | | | ; Interr | | S | | | | | - | upc veccor | | | | 0000 | 40 | | - | | Dark and the second of sec | | 0000 | 40<br>41 | | ORG | · 40 | Reset vector. | | 0000<br>0000 0124 | 40<br>41<br>42 | | - | | ;Reset vector. | | 0000 0124 | 40<br>41<br>42<br>43 | | ORG<br>AJMP | 0<br>Reset | | | 0000 0124 | 40<br>41<br>42<br>43<br>44 | | ORG<br>AJMP<br>ORG | 0<br>Reset<br>03H | External interrupt 0. | | 0000 0124 | 40<br>41<br>42<br>43<br>44<br>45 | | ORG<br>AJMP | 0<br>Reset | | | 0000 0124<br>0003<br>0003 019F | 40<br>41<br>42<br>43<br>44<br>45<br>46 | | ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>ExInt0 | ;External interrupt 0.;Indicates RS-232 start bit received. | | 0000 0124<br>0003<br>0003 019F<br>000B | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47 | | ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>EXInt0 | ;External interrupt 0.<br>;Indicates RS-232 start bit received.<br>;Timer 0 interrupt. | | 0000 0124<br>0003<br>0003 019F | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48 | | ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>ExInt0 | ;External interrupt 0.;Indicates RS-232 start bit received. | | 0000 0124<br>0003<br>0003 019F<br>000B<br>000B 0175 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48 | | ORG<br>AJMP<br>ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0 | ;External interrupt 0.;Indicates RS-232 start bit received.;Timer 0 interrupt.;Baud rate generator. | | 0000 0124<br>0003<br>0003 019F<br>000B<br>000B 0175 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49 | | ORG<br>AJMP<br>ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>EXInt0 | ;External interrupt 0.<br>;Indicates RS-232 start bit received.<br>;Timer 0 interrupt. | | 0000 0124<br>0003<br>0003 019F<br>000B<br>000B 0175 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50 | | ORG<br>AJMP<br>ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0 | ;External interrupt 0.;Indicates RS-232 start bit received.;Timer 0 interrupt.;Baud rate generator. | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 0013 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51 | | ORG<br>AJMP<br>ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0 | ;External interrupt 0.<br>;Indicates RS-232 start bit received.<br>;Timer 0 interrupt.<br>;Baud rate generator.<br>;External interrupt 1 (not used). | | 0000 0124<br>0003<br>0003 019F<br>000B<br>000B 0175<br>0013<br>0013 32<br>001B | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53 | | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0 | ;External interrupt 0.;Indicates RS-232 start bit received.;Timer 0 interrupt.;Baud rate generator. | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 0013 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53 | | ORG<br>AJMP<br>ORG<br>AJMP<br>ORG<br>AJMP | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0 | ;External interrupt 0.<br>;Indicates RS-232 start bit received.<br>;Timer 0 interrupt.<br>;Baud rate generator.<br>;External interrupt 1 (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55 | | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0<br>13H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32<br>0023 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56 | | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0 | ;External interrupt 0.<br>;Indicates RS-232 start bit received.<br>;Timer 0 interrupt.<br>;Baud rate generator.<br>;External interrupt 1 (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>57 | | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG | 0<br>Reset<br>03H<br>ExInt0<br>0BH<br>Timr0<br>13H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32<br>0023 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>55<br>56<br>57 | | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG | 0 Reset 03H EXInt0 0BH Timr0 13H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32<br>0023 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>57<br>57<br>58<br>59 | ***** | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG | 0 Reset 03H EXInt0 0BH Timr0 13H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32<br>0023 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>57<br>58<br>59<br>60 | ***** | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI | 0 Reset 03H EXInt0 0BH Timr0 13H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). | | 0000 0124<br>0003 019F<br>000B 0175<br>0013 32<br>001B 001B 32<br>0023 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>60<br>61 | ***** | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI | 0 Reset 03H EXInt0 0BH Timr0 13H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). | | 0000 0124 0003 019F 000B 0175 0013 0013 32 001B 001B 32 0023 0023 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>60<br>61<br>62 | ;*****; | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI | 0 Reset 03H EXINt0 0BH Timr0 13H 1BH 23H | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). | | 0000 0124<br>0003 019F<br>000B<br>000B 0175<br>0013 32<br>001B 001B 32<br>0023 0023 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>50<br>51<br>52<br>53<br>54<br>55<br>57<br>58<br>60<br>61<br>62<br>63 | ***** | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI ORG RETI | 0 Reset 03H EXINTO 0BH TimrO 13H 1BH 23H ********************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;12C interrupt (not used). | | 0000 0124 0003 019F 000B 0175 0013 32 001B 001B 32 0023 32 0024 758130 0027 752000 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62<br>63<br>64 | ;*****; | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI ORG RETI ORG RETI | O Reset 03H EXIntO 0BH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). | | 0000 0124 0003 019F 000B 0175 0013 32 001B 32 001B 32 0023 32 0023 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62<br>63<br>64<br>65 | ;*****; | ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI ORG RETI MOV MOV CLR | O Reset 03H EXINTO 0BH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). *********************************** | | 0000 0124 0003 019F 000B 0175 0013 32 001B 01B 32 0023 32 0023 32 0024 758130 0027 752000 002A C201 002C 758800 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>60<br>61<br>62<br>63<br>64<br>65<br>66<br>66 | ;*****; | ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI WOV MOV CLR MOV | O Reset 03H EXINTO OBH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;12C interrupt (not used). *********************************** | | 0000 0124 0003 019F 000B 0175 0013 32 001B 32 001B 32 0023 32 0023 32 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62<br>63<br>64<br>66<br>66<br>67 | ;*****; | ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI ORG RETI MOV MOV CLR | O Reset 03H EXINTO 0BH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). *********************************** | | 0000 0124 0003 019F 000B 0175 0013 32 001B 001B 32 0023 32 0024 758130 0027 752000 002A C201 002C 758800 002F 75A882 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62<br>63<br>64<br>65<br>66<br>66<br>67<br>68 | ;*****; | ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI ORG RETI CORG CO | O Reset O3H EXINTO OBH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). *********************************** | | 0000 0124 0003 019F 000B 0175 0013 0013 32 001B 001B 32 0023 0023 32 0024 758130 0027 752000 002A C201 002C 758800 002F 75A882 0032 751310 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>60<br>61<br>62<br>63<br>64<br>64<br>66<br>66<br>66<br>66<br>66<br>66<br>66<br>66<br>66<br>66<br>66 | ;*****; | ORG AJMP ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI CORG CO | O Reset 03H EXINTO 0BH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). *********************************** | | 0000 0124 0003 019F 000B 0175 0013 32 001B 001B 32 0023 32 0024 758130 0027 752000 002A C201 002C 758800 002F 75A882 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62<br>63<br>64<br>65<br>66<br>66<br>67<br>68 | ;*****; | ORG AJMP ORG AJMP ORG RETI ORG RETI ORG RETI ORG RETI CORG CO | O Reset O3H EXINTO OBH TimrO 13H 1BH 23H ******************************** | ;External interrupt 0. ;Indicates RS-232 start bit received. ;Timer 0 interrupt. ;Baud rate generator. ;External interrupt 1 (not used). ;Timer I interrupt (not used). ;I2C interrupt (not used). *********************************** | AN423 | 003A 11FB | 72 | Loop1: | ACALL | Mess | ;Send an RS-232 message repeatedly. | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 003C 743A | 73 | | MOV | A,#':' | | | 003E 1154 | 74 | | ACALL | XmtByte | | | 0040 E9 | 75 | | MOV | A,R1 | | | 0041 11DD | 76 | | ACALL | PrByte | ;Print R1 contents. | | 0043 09 | 77 | | INC | R1 | ; Advance R1 value. | | 0044 D513F3 | 78 | | DJNZ | LoopCnt,Loop1 | | | | 79 | | | | | | 0047 D2A8 | 80 | Loop2: | SETB | EX0 | ; Enable interrupt 0 (RS-232 receive). | | 0049 3003FD | 81 | | JNB | RcvRdy,\$ | ;Wait for data available. | | 004C C203 | 82 | | CLR | RcvRdy | | | 004E E511 | 83 | | MOV | A, RcvDat | ;Echo same byte. | | 0050 1154 | 84 | | ACALL | XmtByte | | | 0052 80F3 | 85 | | SJMP | Loop2 | | | | 86 | | | | | | | 87 | | | | | | | 88 | ; Send a | byte out | RS-232 and wait for | completion before returning. | | | 89 | | | | while RS-232 is busy) | | | 90 | | | | | | 0054 2001FD | 91 | XmtByte: | JB | RxFlag,\$ | ;Wait for receive complete. | | 0057 115D | 92 | - | ACALL | RSXmt | ; Send ACC to RS-232 output. | | 0059 2000FD | 93 | | JB | TxFlag,\$ | ;Wait for transmit complete. | | 005C 22 | 94 | | RET | | | | | 95 | | | | | | | 96 | | | | | | | 97 | ; Begin | RS-232 ti | cansmit. | | | | 98 | | | | | | 005D F510 | . 99 | RSXmt: | MOV | XmtDat,A | ;Save data to be transmitted. | | 005F 75120A | 100 | | MOV | BitCnt,#10 | ;Set bit count. | | 0062 758CFF | 101 | | MOV | TH, #High BaudVal | ;Set timer for baud rate. | | 0065 758A75 | 102 | | MOV | TL, #Low BaudVal | | | 0068 758DFF | 103 | | MOV | RTH, #High BaudVal | ;Also set timer reload value. | | 006B 758B75 | 104 | | MOV | RTL, #Low BaudVal | | | 006E D28C | 105 | | SETB | TR | ;Start timer. | | 0070 C290 | 106 | | CLR | TxD | ;Begin start bit. | | 0072 D200 | 107 | | SETB | TxFlag | ;Set transmit-in-progress flag. | | 0074 22 | 108 | | RET | | | | | 109 | | | | | | | 110 | | | | | | | 111 | - · · · | | 000 1 11: | | | | 111 | ; Timer | 0 timeout | t: RS-232 receive bit | or transmit bit. | | | 112 | ; Timer | 0 timeout | t: RS-232 receive bit | or transmit bit. | | 0075 C0E0 | | ; Timer Timr0: | 0 timeout | ACC | or transmit bit. | | 0075 C0E0<br>0077 C0D0 | 112 | | | | or transmit bit. | | | 112<br>113 | | PUSH | ACC | | | 0077 C0D0 | 112<br>113<br>114 | | PUSH<br>PUSH | ACC<br>PSW | ; Is this a receive timer interrupt?; Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E | 112<br>113<br>114<br>115 | | PUSH<br>PUSH<br>JB | ACC<br>PSW<br>RxFlag,RxBit | ;Is this a receive timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007 | 112<br>113<br>114<br>115<br>116 | Timr0: | PUSH<br>PUSH<br>JB<br>JB | ACC<br>PSW<br>RxFlag,RxBit<br>TxFlag,TxBit | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C | 112<br>113<br>114<br>115<br>116<br>117 | Timr0: | PUSH<br>PUSH<br>JB<br>JB<br>CLR | ACC<br>PSW<br>RXFlag,RXBit<br>TXFlag,TXBit<br>TR | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 CODO<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 DODO | 112<br>113<br>114<br>115<br>116<br>117<br>118 | Timr0: | PUSH<br>PUSH<br>JB<br>JB<br>CLR<br>POP | ACC<br>PSW<br>RxFlag,RxBit<br>TxFlag,TxBit<br>TR<br>PSW | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119 | Timr0: | PUSH<br>PUSH<br>JB<br>JB<br>CLR<br>POP<br>POP | ACC<br>PSW<br>RxFlag,RxBit<br>TxFlag,TxBit<br>TR<br>PSW | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120 | Timr0: T0Ex1: T0Ex2: | PUSH<br>PUSH<br>JB<br>JB<br>CLR<br>POP<br>POP<br>RETI | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121 | Timr0: T0Ex1: T0Ex2: | PUSH<br>PUSH<br>JB<br>JB<br>CLR<br>POP<br>POP<br>RETI | ACC<br>PSW<br>RxFlag,RxBit<br>TxFlag,TxBit<br>TR<br>PSW | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 CODO<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 DODO<br>0083 DOEO<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124 | Timr0: T0Ex1: T0Ex2: | PUSH<br>PUSH<br>JB<br>JB<br>CLR<br>POP<br>POP<br>RETI | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125 | Timr0: T0Ex1: T0Ex2: | PUSH PUSH JB JB CLR POP POP RETI | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124 | Timr0: T0Ex1: T0Ex2: ; RS-232 | PUSH PUSH JB JB CLR POP POP RETI transmi | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC | ;Is this a receive timer interrupt?;Is this a transmit timer interrupt?;Stop timer. | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125 | Timr0: T0Ex1: T0Ex2: ; RS-232 | PUSH PUSH JB JB CLR POP POP RETI | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128 | Timr0: T0Ex1: T0Ex2: ; RS-232 | PUSH PUSH JB JB CLR POP POP RETI transmi | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC t bit routine. BitCnt,TxBusy TxFlag | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127 | Timr0: T0Ex1: T0Ex2: | PUSH PUSH JB JB CLR POP POP RETI transmi | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC t bit routine. BitCnt,TxBusy TxFlag | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit DJNZ CLR SJMP | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy Txrlag T0Ex1 | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. | | 0077 C0D0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 D0D0<br>0083 D0E0<br>0085 32<br>0086 D51204<br>0089 C200<br>008B 80F2 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: | PUSH PUSH JB JB CLR POP POP RETI transmit DJNZ CLR SJMP | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy TxFlag TOEx1 A,BitCnt | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. | | 0077 CODO<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 DODO<br>0083 DOEO<br>0085 32<br>0086 D51204<br>0089 C200<br>008B 80F2<br>008D E512<br>008F B40104 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit DJNZ CLR SJMP MOV CJNE | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy TxFlag T0Ex1 A,BitCnt A,#1,TxNext | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit CUR DJNZ CLR SJMP MOV CJNE SETB | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy Txrlag T0Ex1 A,BitCnt A,#1,TxNext TxD | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. | | 0077 COD0<br>0079 20013E<br>007C 200007<br>007F C28C<br>0081 DOD0<br>0083 DOE0<br>0085 32<br>0086 D51204<br>0089 C200<br>008B 80F2<br>008D E512<br>008F B40104<br>0092 D290<br>0094 80EB | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>133 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit CLR SJMP MOV CJNE SETB | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy Txrlag T0Ex1 A,BitCnt A,#1,TxNext TxD | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 0088 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit DJNZ CLR SJMP MOV CJNE SETB SJMP | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy TxFlag T0Ex1 A,BitCnt A,#1,TxNext TxD T0Ex2 | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>135 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: | PUSH PUSH JB JB CLR POP POP RETI C transmid CLR SJMP MOV CJNE SETB SJMP | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy TxFlag T0Ex1 A,BitCnt A,#1,TxNext TxD T0Ex2 A,XmtDat | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 009B 9290 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>136<br>137 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: | PUSH PUSH JB JB JB CLR POP POP RETI CTR DJNZ CLR SJMP MOV CJNE SETB SJMP MOV RRC | ACC PSW RxFlag, RxBit Txrlag, TxBit TR PSW ACC bit routine. BitCnt, TxBusy TxFlag T0Ex1 A, BitCnt A, #1, TxNext TxD T0Ex2 A, XmtDat A XmtDat, A TxD, C | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>136<br>137 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: | PUSH PUSH JB JB CLR POP POP RETI C transmit DJNZ CLR SJMP MOV CJNE SETB SJMP MOV RRC MOV | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy TxFlag TOEx1 A,BitCnt A,#1,TxNext TxD TOEx2 A,XmtDat A XmtDat,A | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 009B 9290 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>136<br>137 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: | PUSH PUSH JB JB CLR POP POP RETI CTRNSMIC CLR POP POP RETI CTRNSMIC CLR SJMP MOV CJNE SETB SJMP MOV RRC MOV RRC MOV MOV | ACC PSW RxFlag, RxBit Txrlag, TxBit TR PSW ACC bit routine. BitCnt, TxBusy TxFlag T0Ex1 A, BitCnt A, #1, TxNext TxD T0Ex2 A, XmtDat A XmtDat, A TxD, C | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. ;Send data bit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 009B 9290 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>136<br>137<br>138<br>139<br>131 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: TxNext: | PUSH PUSH JB JB CLR POP POP RETI CTRANSMIC CTR | ACC PSW RxFlag, RxBit TxFlag, TxBit TR PSW ACC bit routine. BitCnt, TxBusy TxFlag TOEx1 A, BitCnt A, #1, TxNext TxD TOEx2 A, XmtDat A XmtDat, A TxD, C TOEx2 | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. ;Send data bit. ;Exit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 009B 9290 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>136<br>137<br>138<br>139<br>139<br>140<br>141 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: TxNext: | PUSH PUSH JB JB CLR POP POP RETI CTRANSMIC CTR | ACC PSW RxFlag, RxBit Txrlag, TxBit TR PSW ACC bit routine. BitCnt, TxBusy TxFlag T0Ex1 A, BitCnt A, #1, TxNext TxD T0Ex2 A, XmtDat A XmtDat, A TxD, C | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. ;Send data bit. ;Exit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008P B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 0098 9290 0090 80E2 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>138<br>131<br>132<br>133<br>134<br>135<br>136<br>137<br>138<br>139<br>140 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: TxNext: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit CLR SJMP MOV CJNE SETB SJMP MOV RRC MOV MOV SJMP | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy Txrlag T0Ex1 A,BitCnt A,#1,TxNext TxD T0Ex2 A,XmtDat A XmtDat,A TxD,C T0Ex2 ceive (after external | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. ;Send data bit. ;Exit. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 0098 9290 0090 80E2 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129<br>130<br>131<br>132<br>133<br>134<br>135<br>136<br>137<br>138<br>139<br>140<br>141<br>142<br>143 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: TxNext: | PUSH PUSH JB JB CLR POP POP RETI CTANSMIT CTANSM | ACC PSW RxFlag,RxBit TxFlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy TxFlag TOEx1 A,BitCnt A,#1,TxNext TxD TOEx2 A,XmtDat A TxD,C TOEx2 ceive (after external BitCnt,#10 | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. ;Send data bit. ;Exit. interrupt 0). ;Set receive bit count. | | 0077 CODO 0079 20013E 007C 200007 007F C28C 0081 DODO 0083 DOEO 0085 32 0086 D51204 0089 C200 008B 80F2 008D E512 008F B40104 0092 D290 0094 80EB 0096 E510 0098 13 0099 F510 009B 9290 009D 80E2 | 112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>138<br>131<br>132<br>133<br>134<br>135<br>136<br>137<br>138<br>139<br>140 | Timr0: T0Ex1: T0Ex2: ; RS-232 TxBit: TxBusy: TxNext: | PUSH PUSH JB JB CLR POP POP RETI Ctransmit CLR SJMP MOV CJNE SETB SJMP MOV RRC MOV MOV SJMP | ACC PSW RxFlag,RxBit Txrlag,TxBit TR PSW ACC bit routine. BitCnt,TxBusy Txrlag T0Ex1 A,BitCnt A,#1,TxNext TxD T0Ex2 A,XmtDat A XmtDat,A TxD,C T0Ex2 ceive (after external | ;Is this a receive timer interrupt? ;Is this a transmit timer interrupt? ;Stop timer. ;Decrement bit count, test for done. ;End of stop bit, release timer. ;Stop timer and exit. ;Get bit count. ;Is this a stop bit? ;Set stop bit. ;Exit. ;Get data. ;Advance to next bit. ;Send data bit. ;Exit. interrupt 0). | AN423 | 00A5 758AD9 | 145 | MOV | mr #r C++11-1 | | |-------------|-------------|-----------|------------------------------|--------------------------------------| | | | | TL, #Low StrtVal | | | 00A8 758DFF | 146 | MOV | RTH, #High BaudVa | 1 ;Set timer reload for baud rate. | | 00AB 758B75 | 147 | MOV | RTL, #Low BaudVal | | | 00AE 751100 | 148 | MOV | | | | | | | RcvDat,#0 | ;Initialize received data to 0. | | 00B1 C2A8 | 149 | CLR | EX0 | ;Disable external interrupt 0. | | 00B3 C202 | 150 | CLR | RxErr | ;Clear error flag. | | 00B5 D28C | 151 | SETB | TR | | | | | | | ;Start timer. | | 00B7 D201 | 152 | SETB | RxFlag | ;Set receive-in-progress flag. | | 00B9 32 | 153 | RETI | | | | | 154 | | | | | | | | | | | | 155 | | | | | | 156 ; RS-23 | 2 receiv | e bit routine. | | | | 157 | | | | | 00BA D5120D | | | | | | | 158 RxBit: | DJNZ | BitCnt,RxBusy | ;Decrement bit count, test for stop. | | 00BD 209502 | 159 | JB | RxD,RxBitEx | ;Valid stop bit? | | 00C0 D202 | 160 RxBtErr | : SETB | RxErr | ;Bad stop bit, tell mainline. | | 00C2 C201 | 161 RxBitEx | | | | | | | | RxFlag | ;Release timer for other purposes. | | 00C4 D2A8 | 162 | SETB | EX0 | ;Re-enable external interrupt 0. | | 00C6 D203 | 163 | SETB | RcvRdy | ;Tell mainline that a byte is ready. | | 00C8 80B5 | 164 | SJMP | T0Ex1 | | | 0000 0000 | | SOME | TOEXI | ;Stop timer and exit. | | | 165 | | | | | 00CA E512 | 166 RxBusy: | MOV | A,BitCnt | ;Get bit count. | | 00CC B40905 | 167 | CJNE | A, #9, RxNext | ;Is this a start bit? | | 00CF 2095EE | 168 | JB | | | | | | | RxD, RxBtErr | ;Valid start bit? | | 00D2 80AD | 169 | SJMP | T0Ex2 | ;Exit. | | | 170 | | | | | 00D4 E511 | 171 RxNext: | MOV | A, RcvDat | .Ook mouti-1 but- | | | | | | Get partial receive byte. | | 00D6 A295 | 172 | MOV | C,RxD | ;Get receive pin value. | | 00D8 13 | 173 | RRC | Α | ;Shift in new bit. | | 00D9 F511 | 174 | MOV | RcvDat, A | | | | | | | ;Save updated receive byte. | | 00DB 80A4 | 175 | SJMP | T0Ex2 | ;Exit. | | | 176 | | | | | | 177 | | | | | | 178 ; Print | hasha san | | | | | | . Dyce ic | dutine: print ACC cont | tents as ASCII hexadecimal. | | | 179 | | | | | 00DD C0E0 | 180 PrByte: | PUSH | ACC | | | 00DF C4 | 181 | SWAP | A | | | 00E0 11EB | | | | | | | 182 | ACALL | HexAsc | | | 00E2 1154 | 183 | ACALL | XmtByte | | | 00E4 D0E0 | 184 | POP | ACC | | | 00E6 11EB | 185 | | | n. 1 | | | | ACALL | | Print nibble in ACC as ASCII hex. | | 00E8 1154 | 186 | ACALL | XmtByte | | | 00EA 22 | 187 | RET | | | | | 188 | | | | | | | | | | | | 189 | 1 | | | | | 190 ; Hexad | ecimal t | o ASCII conversion ro | outine. | | | 191 | | | | | 00EB 540F | 192 HexAsc: | ANL | A,#0FH ;0 | Convert a nibble to ASCII hex. | | 00ED 30E308 | 193 | | | convert a himble to Ascii hex. | | | | JNB | ACC.3, NoAdj | -0 | | 00F0 20E203 | 194 | JB | ACC.2,Adj | | | 00F3 30E102 | 195 | JNB | ACC.1,NoAdj | | | 00F6 2407 | 196 Adj: | ADD | A, #07H | | | | | | | | | 00F8 2430 | 197 NoAdj: | ADD | A,#30H | | | 00FA 22 | 198 | RET | and the second of the second | | | | 199 | | | | | | 200 | | | | | | | | | | | | | ge strin | g transmit routine. | | | | 202 | | | | | 00FB C0E0 | 203 Mess: | PUSH | ACC | | | 00FD 7800 | 204 | MOV | | 70 to 1 | | | | | R0,#0 | ;R0 is character pointer (string | | 00FF E8 | 205 Mesl: | MOV | A,RO | ; length is limited to 256 bytes). | | 0100 93 | 206 | MOVC | A, @A+DPTR | ;Get byte to send. | | 0101 B40003 | 207 | CJNE | | | | | | | A,#0,Send | ;End of string is indicated by a 0. | | 0104 D0E0 | 208 | POP | ACC | | | 0106 22 | 209 | RET | | | | | 210 | | | | | 0107 1154 | 211 Send: | ACALL | Vmt Drot - | | | | | | XmtByte | ;Send a character. | | 0109 08 | 212 | INC | R0 | ;Next character. | | 010A 80F3 | 213 | SJMP | Mesl | | | | 214 | | | | | 010C 0D0A | 215 Msg1: | DB | 0Dh, 0Ah | | | | magi. | 22 | ODII, OAII | | | | | | | | November 1989 418 AN423 | 010E 54686973 | 216 DB | 'This is a to | est of the software seria | 1 routines.', 0 | |--------------------|--------------------|---------------|---------------------------|-----------------| | 0112 20697320 | | | | | | 0116 61207465 | | | | | | 011A 7374206F | | | | | | 011E 66207468 | | | | | | 0122 6520736F | | | | | | 0126 66747761 | | | | | | 012A 72652073 | | | | | | 012E 65726961 | | | | | | 0132 6C20726F | | | | | | 0136 7574696E | | | | | | 013A 65732E00 | 0.4.7 | | | | | | 217 | | | | | | 218 ENI | | | | | ASSEMBLY COMPLETE, | 0 ERRORS FOUND | | | | | | 보다 경기에 가지를 만큼 그 보다 | | | | | | | | | | | ACC | D ADDI | | | | | ADJ | C ADDI | | | | | BAUDVAL | NUM | | | | | BITCNT | D ADDI | | | | | EXO | B ADD | | | | | EXINTO | | | | | | FLAGS | D ADD | | | | | IE | D ADD | | | | | LOOP1 | C ADD | | | | | LOOP2 | C ADD | | | | | LOOPCNT | D ADD | | | | | MESL | C ADD | | | | | MESS | C ADD | R 00FBH | | | | MSG1 | C ADD | R 010CH | | | | NOADJ | C ADD | | | | | P1 | | | | | | PRBYTE | | | | | | PSW | | | | | | RCVDAT | | | | | | RCVRDY | | | | | | RESET | C ADD | | | | | RTH | | | | | | RTL | D ADD | | | | | RXBIT | C ADD | | | | | RXBITEX | C ADD | | | | | RXBTERR | | | | | | RXBUSY | C ADD | R 00CAH | | | | RXD | B ADD | R 0095H | | | | RXERR | B ADD | | | | | RXFLAG | B ADD | | | | | RXNEXT | C ADD | | | | | SEND | C ADD | | | | | SP | | | | | | STRTVAL | | | | | | TOEX1 | | | | | | TOEX2 | | | | | | TH | | | | | | TIMRO | C ADE | | | | | TL | D ADE | | | | | TR | | | | | | TXBIT | C ADE | | | | | TXBUSY | C ADD | | | | | TXD | B ADD | | | | | TXFLAG | B ADD | | | | | TXNEXT | C ADE | or 0096H | | | | XMTBYTE | C ADE | | | | | XMTDAT | D ADD | OR 0010H | | | | | | | | | | | | | | | **AN426** Author: Bill Houghton ## INTRODUCTION Often, certain classes of microcontroller applications surface where large amounts of on-chip resources such as a large program memory space and numerous I/O pins are not required. These applications are typically cost sensitive and desirable attributes of the MCU include low cost and modest on-chip resources such as program and data memory, I/O, and timer-counters. Substantial benefits of reduced design cycle time can be realized by using an industry-standard architecture having software compatibility with existing popular microcontrollers. ## **THE 87C751** The Philips 87C751 is one such microcontroller that easily meets these requirements. This device, shown in Figure 1, has a 2k x 8 program memory, 64 bytes of RAM, 19 parallel I/O lines, and a 16-bit autoreload timer-counter. It also includes an I<sup>2</sup>C serial interface and a fixed rate timer. The 87C751 is based on the 80C51 core and thus uses an industry-standard architecture and instruction set. The device is available in both ROM (83C751) and EPROM (87C751) versions. The EPROM version is available in both UV erasable and OTP packages. References to the 87C751 in this document also apply to the 83C751, unless explicitly stated. ## TYPICAL APPLICATION A typical example of such an application is the interface between the 87C751 and the Philips SA5775 Air Core Meter Driver shown in Figure 2. This circuit includes the 87C751 microcontroller, the SA5775 air core meter driver, an NE555 timer, and discrete support components. An air core meter differs from a conventional (d'Arsonval) meter movement in that it has no spring to return the needle to a predetermined position, no zeroing adjustment, and no permanent magnet in the classical sense. Instead, it consists of two coils of wire wound in quadrature with each other around a central core in which there is a disc magnetized along its diameter. A shaft is placed through the center of this disc so that the shaft rotates with the disc. An indicating needle attached to this shaft will rotate with it. ## SA5775 Air Core Meter Driver The SA5775 is a monolithic driver for controlling air core meters typically used in automotive instrument clusters and is shown in Figure 3. The SA5775 receives a 10-bit serial word and converts that word to four voltage outputs that appear at the SINE+, SINE-, COSINE+, and COSINE- outputs. The differential voltage at the SINE outputs are applied to one coil of the meter and the COSINE outputs are applied to the other coil of the meter The currents through these coils produce a resultant magnetic force which is the vector sum of the magnetic forces produced by each of the two coils. Since the currents through the coils are bidirectional this magnetic vector can rotate through a full 360 degrees. The magnetized disc within the air core meter will follow the rotating vector and the needle will indicate the vector's current position. Since 10 bits are used, there are 1024 discrete words available resulting in an angular displacement of 0.3516 degrees per bit. This is small enough to provide an apparently smooth movement of the needle. The smoothness of the motion will depend greatly on the damping factor of the meter movement. A simplified block diagram of the SA5775 is shown in Figure 4. This device consists of a serial-in/parallel-out shift register, a data latch, a D/A converter, buffers, and an internal voltage reference. A logic high must be present on the chip select (CS) input to clock in the data. Data appearing on the data input (DI) pin is clocked into the shift register on the rising edge of the clock (CLK) input. The data output (DO) pin is the overflow from the shift register, allowing the user to daisy chain multiple SA5775 devices. Note that data is clocked out of this pin on the falling edge of the clock. The CS pin is also used to latch the parallel outputs of the shift register into the data latch. The outputs of the data latch feed the inputs to the D/A converter. The D/A converter outputs are buffered to form the drive signals for the meter coils. A voltage reference for the D/A converter is provided internally. It is possible to externally force different values for these voltages and pins are provided for this purpose. However, this is not generally recommended as this could lead to increased power dissipation. The D/A converter circuits and its associated output buffers are purposely designed such that the span of these circuits does not include the power supply rails. This is to avoid inaccuracies that would otherwise occur if the output were to become very close to either supply rail. With a supply voltage of 14 volts (VIGN), the positive reference (VREF+) is approximately 8 volts and the negative reference (VREF-) is approximately 1 volt. The outputs will then span a range from 1 volt to approximately 11 volts. The maximum output is [(VREF+) + 0.41((VREF+)-(VREF-))]. The SA5775 is designed to drive air core meters having a minimum winding impedance of 200 ohms. The clock high and low time requirements are each 200 ns minimum, implying a maximum data rate approaching 2.5 megabits per second. At this rate it would require approximately 4 ms to ramp from zero to full scale if all binary codes were loaded into the SA5775. However, the air core meter cannot respond to such data rates. Figure 1. Pin Configuration Figure 2. Interface Between the 87C751 and the Philips SA5775 Philips Semiconductors Application note # Controlling air core meters with the 87C751 and SA5775 AN426 Figure 3. D and N Packages ## 87C751 Microcontroller The 87C751 microcontroller provides all of the intelligence in this application. It samples various input ports to determine which demonstration programs to run, the incremental step sizes for angular displacement of the meter core, and the time delay between increments. In one of the demonstration modes, it also samples a variable frequency input and positions the meter core in response to the frequency of that input. The 87C751 also transmits the 10-bit serial data to the SA5775. Data input (DI), Clock (CLK), and Chip Select (CS) lines are driven from the 87C751. Port 0 of the 87C751 is a 3-bit wide port and is used for communicating data to the ACMD. Data is transmitted, MSB first, in a serial stream clocked into the DI of the SA5775 on the rising edge of the clock. In order to clock in data, the CS pin of the SA5775 must be high. The data in the input register is shifted into a latch that drives the DAC on the high to low transition of the CS line. As data is shifted into the ACMD, it overflows through the Data Out (DO) pin on the falling edge of the clock. With this facility, multiple ACMDs can be daisy-drained with DO of one ACMD being connected to DI of the next one, and common clock and chip select lines may be used. This simplifies the interfacing to multiple meter drivers. The 78L05 regulator (Q2) provides 5 Volt power for the board so that single supply of +14 volts can be applied to the board. Three rotary switches are used on this board. The PROGRAM SELECT switch (S3) is used to select the program routine that is executed, the INC SELECT (S2) switch selects the incremental step sizes of the two of the routines, and the DELAY switch (S4) is used to set the delay between successive word transmissions in one of the routines. The START/COUNT button (S5) is used to begin execution of a routine, and to cause the next incremental step in Routine #1. The COUNT UP/DOWN switch (S6) is used in Routine #1 to determine whether the count is increased or decreased with transmission of successive words. #### NE555 Timer The NE555 timer shown in this application example is used as a free running squarewave generator used to simulate sensor inputs such as those which might be found in an automobile, etc. The NE555 timer (U4) operates in the astable mode to produce an output frequency that can be varied from about 1Hz to about 200 Hz. Three of the program routines measure the input period and produce an output code that is proportional to the frequency present at pin 20 (TO) of the microcontroller. A RATE switch (S7) is used to select between the on board oscillator or an external source. The program listing is included at the end of this application note. #### **Program Entry** The program starts at address 030(hex) on line 21 of the program listing. The first task is to write 1's to all pins of each port. Lines 25 and 26 clear registers 6 and 7. These registers are used in this program only to hold the data that is sent out to the ACMD. The registers are cleared to be sure that the starting value is zero. At line 27 the program waits until the START/COUNT button (S5) is depressed before continuing. Lines 28 and 29 set the timer to overflow after 10ms. This is done by setting the timer registers for a count of 10,000 microseconds less than full scale. When the timer counter overflows the timer flag is set, and the timer is reloaded with the value in the timer register. By examining the timer flag we know when 10ms has expired. Line 30 calls subroutine RPS (Read Port Selected), which reads Port 3 to determine which routine has been selected. Since the PROGRAM SELECT switch (S3) is connected to port pins P3.2 through P3.4, subroutine RPS (lines 507 through 511 at the end of the program) first reads Port 3 into the accumulator, then complements it because the switches used are complementary binary. The reading is then rotated right once and the upper nibble and the LSB (least significant bit) are masked off, leaving twice the value of the port selected in the accumulator. Twice the read value is needed for the next few main program lines that determine which routine to execute. Line 31 moves the address of label JMPTBL (Jump Table) to the 16-bit Data Pointer (DPTR) register. Line 32 causes a program jump to the address that is the sum of the value in the accumulator (two times the routine number selected) plus the DPTR register. Since each of the commands on lines 33 through 40 are two byte commands, these addresses are all separated by two bytes; hence, the need for the accumulator to contain a number that is twice the number of the selected routine. #### Routine 0 This routine begins on line 41 by incrementing the 10-bit word in registers 7 and 6 by the amount indicated by the setting of the INCREMENT SELECT switch, then sending that word to the SA5775. When a full scale overflow is detected, a full scale code (3FF hex) is sent out, followed by a delay of 500 ms, then successive output codes are sent out, decremented by an amount indicated by the INCREMENT SELECT switch. When an underflow is detected a code of zero scale is sent and the routine returns to the beginning of the program. This routine is implemented with a series of subroutine calls. The SO subroutine begins on line 356 and starts by sending out whatever ten bits that in the two LSBs of register 7 (R7) plus the 8 bits of R6 by calling the SENDIT subroutine. Then it calls the UP subroutine, which increases the word value to be sent out. The program then jumps to the beginning of this subroutine, repeating the process of sending out a word and incrementing to the next word until an overflow from the tenth bit (bit 2 of R7) is detected at line 362. The SENDIT subroutine (beginning on line 476) brings the CS line high, sets a bit counter (R1) to 2 (to send out two bits of R7), brings the value of R7 to the accumulator, rotates the accumulator to the right three times through the carry bit to bring the two LSBs to the position of the two MSBs, calls the SEND1 routine, which sends the number of bits in the accumulator, starting with the MSB, indicated by R1. Counter R1 is then set to 8 to send out all 8 bit of R6 and the accumulator is loaded with the contents of R6. The SEND1 routine is again called to send out the final 8 bits, and, on line 491, the CS line is brought low, loading the SA5775 internal parallel latch with the contents of the input shift register. Figure 4. Block Diagram of the SA5775 The SEND1 routine rotates the accumulator left through the carry bit, moves the value of the carry bit to port pin PO.1 (SDA—Serial Data pin), waits to provide a setup time, brings the clock low, waits, brings the clock high, waits, then decrements bit counter sends the next bit if the counter is not zero. A return is executed when the counter becomes zero. The UP subroutine, beginning at line 364, reads the delay selected by switch S4 at port pin P1, complements it (again, because the rotary switches are complementary binary), masks off the upper four bits (because the delay switch has just four positions and is connected to the lower four bits of the port), multiplies it by 4 (rotates left twice), then moves the result to R1. If R1 is not zero, the program jumps around line 376 and calls a 10ms delay (subroutine DLY10MS) the number of times entered into R1. The 10ms delay subroutine (starting at line 436) sets the timer for 10ms, waits at line 446 for the timer flag to be set, clears the timer flag, stops the timer, and returns, in this case, to line 379, where the program decrements R1 and repeats the 10ms delay until R1 is zero. If the selected delay was zero, the program jumps from line 376 to line 380 and reads port 3 to determine the amount the sent out word is to change from the value previously sent out. The accumulator is complemented and the upper 6 bits masked off to recover only the two bits of the selected increment amount. Since increments of 1, 2, 3, or 4 LSBs are hardly noticeable, the program then multiplies the result by 8 (rotate left three times). To insure a minimum change amount, the accumulator is increment by one at line 386. This all means that the increment amounts that can be selected are 1, 9, 17, or 25 LSBs. This amount is added, in lines 387 through 391, to the word previously send out and we return from this subroutine. After calling the S0 subroutine, PR0GO call the FULLSC (full scale) subroutine, which sends out the full scale code of 3E8(hex). Although a 10-bit full scale code would be 3FF(hex), going only to 3E8 allows an easy distinction between zero scale and full scale when looking at the display. The FULLSC subroutine is found at line 352. After advancing to full scale, there is a 500ms delay, found at line 464 and called from line 48, then 49 calls the S0D subroutine to send out decreasing word values. The SOD subroutine begins at line 393 and begins by sending out the current word in R7 and R6 from line 398, then calling subroutine DOWN, which calculates the next (decreasing) word to send out. DOWN begins at line 402. It essentially does the same thing as the UP subroutine, but subtracts the INCREMENT SELECT value from the previously sent word rather than adding to it. At line 50 subroutine ZEROSC is called to send a zero scale code to the SA5775, then the program branches back to the beginning. #### Routine 1 This routine is selected with the PROGRAM SELECT switch is in position 1 or position 9. Routine 1 (PROG1) increments or decrements the word send out, depending upon the setting of the COUNT UP/COUNT DOWN switch, S6. The amount of change is determined by the setting of the INC SELECT switch, S2. At line 63, the program examines S6 at port pin P3.6 and jumps to the decrement portion of the routine if the pin is low. If this pin is high, the UP subroutine is called from line 64 to increase the R7/R6 word value. The UP subroutine was previously described. If pin P3.6 is low, the DOWN subroutine (line 402) decreases the previous word sent out by the amount determined from the INC SELECT switch setting. To insure enough delay to allow the user time to release the START/COUNT button (S5), a delay of 200ms is included at line 66 before jumping to line 27, where another depression of the START/COUNT button is awaited. If S3 (PROGRAM SELECT) is still set to 1 or 9, depression of S5 will cause a jump back to line 52. If another program is selected, the program will jump to the selected routine. Holding down S5 with PROGRAM SELECT set at position 1 or 9 will cause increasing or decreasing word values to be sent to the SA5775. AN426 #### Routine 2 PROG2 is the most complex of all these routines. The purpose of this routine is to cause the air core meter deflection to represent the frequency presented at the timer/counter input to the microcontroller. This is done by measuring the period of the input square wave and taking the inverse of the period. The input here must be a square wave because a slow rise and fall time at this input will cause fluctuating readings. To determine the frequency by counting pulses for a time would require a much longer time and, therefore, is impractical. The MEAS (measure) subroutine is called at line 79 to measure the period of the input waveform and the CALC (calculate) subroutine is called at line 80 to calculate the code to send to the SA5775. The SENDIT subroutine is then called to send the word to the SA5775 and the program jumps back to line 28. The MEAS subroutine begins at line 83 by being sure the timer is not running and clearing the timer (overflow) flag, then entering zero into both high and low bytes of the timer and the timer register. The carry bit is then cleared (line 90) and the timer started and the timer interrupt enabled. Lines 93 and 94 form a short loop that waits until either the carry bit is set or until the TO input is low. The carry bit is set when the timer has gone beyond one second. This is done by the timer interrupt subroutine, found at lines 16 through 19. If the TO input never goes low, we know the frequency is at or near zero and the program jumps to GZS (line 108) where R3 is loaded with a 1F (hex) to cause the CALC subroutine to load zero scale into R7/R6. When (and if) TO is found to be low, the program jumps to line 95 and waits for that input to go high. Time out process is the same as above. Now that the TO input is found high (if is is before the one second time out), the timer and carry bit are cleared in lines 97 through 100 (R3 is an extension of the timer). At lines 101 through 107 we wait for one complete cycle at the TO input, with the timer/counter measuring that period, then return to line 80, where the CALC subroutine is called. The CALC subroutine, starting at line 113, begins by initializing the word to send out (R7/R6) to zero, clearing the carry bit, checking to see if R3 indicates a time above one second, returning to line 81 if it does. Otherwise the program continues at line 26, where the program checks to see if the input frequency is beyond full scale (timer reading above 00 12 88 hex). If it is, R7/R6 is loaded with 12 88 hex (full scale of decimal 1,000). This value was chosen because it is sufficiently far from zero scale that it is easily discerned from zero scale on the display. If the result is not to be full scale or zero scale, the program continues at line 140 with a shift and subtract divide routine. The dividend would be 1,000,000 (decimal) to convert back to frequency in Hertz (period measurements is in microseconds), but that would provide a maximum count of 200 at 200Hz, only one fifth of the full scale desired of 1,000. So we made the dividend to be 5,000,000 decimal, or 4C 4B 40 hex. This algorithm is found in lines 156 through 192 and works as follows: - 1. Clear a counter. - Rotate dividend until the first one is in the second MSB position. Since a code of 4C has already provides that, no shifting is necessary. - Rotate the divisor (the period in microseconds in this case) left until the first one is in the second MSB position, but the first byte is LESS THAN the first byte of the dividend. Increment the counter each time the divisor is rotated. - Initialize a counter to zero. - Rotate the quotient (answer) and dividend one bit left. - If first byte of quotient is smaller than the first byte of the quotient, jump to step 8. - Add one to the quotient and subtract the divisor from the dividend. - Decrement the counter and go to step 5 if it is not zero. Once the CALC subroutine is completed, the program calls SENDIT from line 81 and jumps, ultimately, to the selected routine. #### Routine 3 PROG3, beginning at line 194, measures the input period four times, then calculates the code to display that is the average of these four readings. It starts by setting a counter for three readings, taking those three readings and storing them in memory, beginning at RAM address 20 hex, using register RO as an index register. At line 212 the program takes a fourth reading, then adds the three previous readings to it in lines 213 through 227; and divides the sum by four (rotates right twice) in lines 229 through 239. The word to send out is then calculated from line 240 and sent to the ACMD, after which the program then looks for and jumps to the selected routine. #### **Routine 4** PROG4 begins at line 243 and displays the average of the current and last three words sent out. RAM space used is first initialized to zero and a new reading is taken and a new word is calculated and saved. At lines 264 through 284, the new word is added to the last three readings and the average calculated and stored in RAM locations 28 and 29 (hex), and the average word is sent out. At line 286, the program reads for the program selected and jumps to line 254 if this routine is selected, otherwise it goes to line 28. #### Routine 5 PROG5 begins at line 293 and, very simply, send in sequence the codes for 1/8 through full scale in 1/8 scale steps, with 500ms between steps. It then steps down to zero scale in 1/8 scale steps, then returns to line 28. #### Routine 6 PROG6 begins at line 314 and does the same as PROG5, but steps in 1/4 scale increments. #### **Routine 7** PROG7 loads the code for 3/8 scale into R7/R6, sends it, waits 500ms, changes r& for 5/8 scale, sends it, waits for 500ms, then repeats this sequence 9 more times (for a total of ten times), waits 500ms, then returns the output to zero scale and the program jumps to line 28. AN426 ``` TT.20 ACMD V3 DEMO 1 PROCESSOR: 87C751 7-29-89 3 4 The purpose of this program is to drive version 3 of the ACMD (SA5775) 5 demonstration board. The PROGRAM SELECT switch is used to select from 6 a choice of four routines. Registers R7 and R6 contain the 10-bit word 7 ρ that is send to the SA5775. q $MOD751 1.0 0000 11 ORG 0 12 0000 B02E 13 SJMP START ; RESET VECTOR 14 000B 00BH ;TIMER/COUNTER INTERRUPT ROUTINE 15 ORG 000B 0B ; INCREMENT R3 (3rd BYTE OF TIMER) 16 TNC R3 A,#OFH ;TEST FOR TIME OUT (R3 > OF) 000C 740F 17 MOV ; IF R3 > OF, CARRY IS SET 000E 9B 18 SUBB A,R3 000F 32 19 RETI 20 0030 21 ORG 30H ;START OF PROGRAM 0030 7580FF 22 START: MOV PO, #OFFH ; SET PORTS HIGH 0033 7590FF P1,#0FFH 23 MOV 0036 75B0FF 24 P3,#0FFH 0039 7F00 R7,#0 ;CLEAR WORD TO SEND OUT 25 MOV 003B 7E00 26 MOV R6,#0 003D 20B6FD ; WAIT FOR START BUTTON DEPRESS 27 w. JTB P3.6,W 0040 758BF0 RTL, #LOW(0-10000) ; SET TIMER REGISTER 28 READY: MOV RTH, #HIGH(0-10000); FOR 10ms TIME 0043 758DD8 29 MOV ; READ PORT 3 FOR PROG SELECT 0046 51D2 30 ACALL. RPS ;JMP ADDRESS TO DATA POINTER 0048 90004C 31 MOV DPTR, #JMPTBL ;GOTO APPROPRIATE ROUTINE 004B 73 32 TMP @A+DPTR ; RAMP UP AND BACK DOWN 004C 015C 33 JMPTBL: AJMP PROG0 004E 0168 34 AJMP PROG1 :STEP UP/DOWN W/ start PRESS ; READ & DISPLAY SPEED 0050 017A 35 AJMP PROG2 0052 2145 36 AJMP PROG3 ; DISPLAY AVERAGE OF 4 NEW READINGS ; DISPLAY AVERAGE OF LAST 4 READINGS 0054 2186 37 AJMP PROG4 ; ADVANCE TO FULL SCALE AND BACK IN 45 DEGREE STEPS 0056 21D3 PROG5 38 AJTMP ; ADVANCE TO FULL SCALE AND BACK IN 90 DEGREE STEPS 0058 21F3 39 AJMP PROG6 ; ALTERNATE DISPLAY BETWEEN 3/8 AND 5/8 SCALE TEN TIMES 005A 4107 40 AJMP PROG7 005C 41 PROG0: This routine increases word sent at the selected step size (INCREMENT SELECT) 42 and delay time (DELAY), up to full scale, waits 500ms, then decreases the 43 word sent at the selected step size and delay times until zero scale is reached. 44 45 ; SEND OUT INCREASING WORDS 005C 5128 46 ACALL SO 005E 5121 47 ACALL FULLSC ; SET TO FULL SCALE 0060 51A5 ;WAIT 500ms 48 ACALL DLY500 0062 5152 ACALL ; SEND OUT DECREASING WORDS 49 SOD 0064 511B 50 ACALL ZEROSC ; RESET TO ZERO SCALE AJMP 0066 0130 51 START :GO TO BEGINNING OF PROGRAM 006B 52 PROG1: 53 54 MANUAL INCREMENT/DECREMENT ROUTINE 55 56 This routine increases or decreases the sent out word, depending upon the setting of the UP/DOWN switch, by an amount set by the INCREMENT 57 58 SELECT switch. There is a wait of 200ms before again looking for 59 depression of the START/COUNT button to allow time to release this button and switch bounce to settle. The program then looks to see which 60 61 routine is selected and goes to that routine. ; 62 0068 30B50B 63 JNB P3.5, DCX ;GO AND COUNT DOWN IF SELECTED 006B 5130 64 ACALL UP ; INCREASE WORD 006D 51B5 65 DP1: ACALL SENDIT :SEND THE WORD 006F 519D 66 ACALL DLY200 :WAIT 200ms 0071 013D 67 AJMP ; WAIT FOR COUNT BUTTON DEPRESS & SELECTED ROUTINE 0073 20B5F2 68 DCX: JB P3.5, PROG1 ;GO AND COUNT UP IF SELECTED 0076 515A 69 ACALL DOWN ; DECREASE WORD ``` 425 AN426 ``` 0078 80F3 70 SJMP DP1 007A 71 PROG2: 72 73 READ TIME INPUT AND DISPLAY "SPEED" 74 This routine measures the period of the square wave at the TO input and 75 76 .; sends out a word that is inversely proportional to 5 times that period, 77 providing a display proportional to frequency. 78 007A 1182 79 ACALL MEAS ; MEASURE THE INPUT PERIOD 007C 11C5 80 ACALL CALC ; CALCULATE THE WORD TO SEND 007E 51B5 81 ACALL SENDIT ; SEND OUT THE WORD 0080 0140 82 AJMP READY 0082 C28C 83 MEAS: CLR TR ;HALT TIMER 0084 C28D 84 CLR TF ;CLEAR TIMER FLAG 0086 758B00 85 MOV RTL,#0 ;SET TIMER REGISTERS 0089 758D00 86 MOV RTH, #0 008C 758A00 87 MOV TL,#0 ;SET TIMER 008F 758C00 88 MOV TH, #0 0092 7B00 89 MOV R3,#0 ;CLEAR TIMER 3RD BYTE 0094 C3 90 CLR C 0095 D28C 91 SETB TR ;START TIMER 0097 75A882 92 MOV IE,#82H ; ENABLE TIMER INTERRUPT 009A 4021 93 W20: JC GZS ;JUMP IF R3 > OF 009C 2097FB P1.7,W20 JB ;WAIT FOR TO INPUT LOW 009F 401C 95 W21: JC GZS ;JUMP IF R3 > OF 00A1 3097FB 96 JNB P1.7,W21 ;WAIT FOR TO INPUT HIGH 00A4 758A00 97 MOV TL,#0 ; RESET TIMER 00A7 758C00 98 MOV TH.#0 00AA 7B00 99 MOV R3,#0 00AC C3 100 CT.R C ; CLEAR CARRY/BORROW 00AD 4008 101 W22: JC HT ;JUMP IF TIME UP (CARRY SET) 00AF 2097FB 102 JB P1.7,W22 ;WAIT FOR TO LOW 00B2 4003 103 W23: HT ;JUMP IF TIME UP (CARRY SET) 00B4 3097FB 104 JNB P1.7,W23 ;WAIT FOR TO HIGH AGAIN 00B7 C28C 105 HT: CLR TR ;HALT TIMER 00B9 75A800 106 MOV IE,#0 ;DISABLE ALL INTERRUPTS 00BC 22 107 RET 00BD 7B1F 108 GZS: MOV R3,#1FH ; SET FOR ZERO SCALE 00BF 22 109 RET 00C0 7F03 110 GFS: MOV R7,#03 00C2 7EE8 111 MOV R6,#0E8H OOC4 22 112 00C5 113 CALC 114 115 This subroutine calculates the 10-bit word to send as a function fo what is in R3, TH & TL. The 10-bit word is developed and left in registers 116 117 ; R7 and R6 for use by SENDIT subroutine. 118 ; 00C5 7F00 119 MOV R7,#0 ; INITIALIZE QUOTIENT 00C7 7E00 120 MOV R6,#0 00C9 C3 121 CLR ;CLEAR CARRY/BORROW 00CA 740F 122 MOV A.#OFH ; CHECK FOR ZERO SCALE 00CC 9B 123 SUBB A.R3 00CD 5001 124 JNC NZS ;JUMP IF NOT ZERO SCALE 00CF 22 125 RET 00D0 E58A 126 NZS: VOM A,TL ; CHECK FOR FULL SCALE 00D2 9488 127 SUBB A,#88H 00D4 E58C 128 VOM A, TH 00D6 9413 129 SUBB A,#13H 00D8 EB 130 VOM A,R3 00D9 9400 131 SUBB A.#0 00DB 40E3 132 JC 00DD 752E4C 133 MOV 2EH, #4CH ;SET DIVIDEND TO 5,000,000 00E0 752F4B 134 VOM 2FH, #4BH 00E3 753040 135 MOV 30H, #40H 00E6 7C00 136 MOV R4,#0 ;CLEAR DIVIDE COUNTER 00E8 8B2B 137 MOV 2BH.R3 ; MOVE READING TO MEMORY (DIVISOR) 00EA 858C2C 138 MOV 2CH, TH ``` January 1992 AN426 | 00ED 858A2D | 139 | | MOV | 2DH, TL | | |----------------------------------------------|--------------------------|--------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | 00F0 C3 | 140 | ROTL: | CLR | C ; BRING DIVISOR BE JUST LESS THAN DIVIDEND | | | 00F1 E52E | 141 | | MOV | A, 2EH | | | 00F3 952B | 142 | | SUBB | A, 2BH | | | 00F5 4014 | 143 | | JC | DIV24 ;JUMP IF SHIFTING WOULD MAKE DIVISOR > DIVIDEN | D | | 00F7 6012 | 144 | | JZ | DIV24 ;JUMP IF DIVISOR & DIVIDEND MS BYTES EQUAL BEF | | | 00F9 E52D | | | | | ORE SHIFT | | | 145 | | MOV | A,2DH ;SHIFT DIVISOR TO LEFT | | | 00FB 33 | 146 | | RLC | A decision of the control con | | | 00FC F52D | 147 | | MOV | 2DH, A | | | 00FE E52C | 148 | | VOM | A, 2CH | | | 0100 33 | 149 | | RLC | | | | 0101 F52C | 150 | | MOV | 2CH, A | | | 0103 E52B | 151 | | VOM | A, 2BH | | | 0105 33 | 152 | | RLC | $oldsymbol{\mathtt{A}}$ . The second control of | | | 0106 F52B | 153 | | MOV | 2BH, A | | | 0108 OC | 154 | | INC | R4 | | | 0109 80E5 | 155 | | SJMP | ROTL | | | 010B C3 | 156 | DIV24: | | C | | | 010C EE | | DIVZ4. | | | | | | 157 | | VOM | A,R6 ;ROTATE QUOTIENT LEFT | | | 010D 33 | 158 | | RLC | | | | 010E FE | 159 | | VOM | R6,A | | | 010F EF | 160 | | MOV | A,R7 | | | 0110 33 | 161 | | RLC | | | | 0111 FF | 162 | | VOM | R7,A | | | 0112 C3 | 163 | | CLR | C ; ROTATE DIVIDEND LEFT | | | 0113 E530 | 164 | | MOV | A,30H | | | 0115 33 | 165 | | RLC | A | | | 0116 F530 | 166 | | MOV | 30H, A | | | 0118 E52F | 167 | | MOV | A, 2FH | | | 011A 33 | 168 | | RLC | A | | | 011B F52F | 169 | | MOV | | | | 011D F52F | | | | 2FH, A | | | 011F 33 | 170 | | MOV | A, 2EH | | | | 171 | | RLC | A | | | 0120 F52E | 172 | | MOV | 2EH, A | | | 0122 C3 | 173 | | CLR | C ;TEST SUBTRACT MOST SIGNIFICANT BYTES | | | 0123 952B | 174 | | SUBB | A, 2BH | | | 0125 401B | 175 | | JC | ZERO ; JUMP IF QUOTIENT MS BYTE < DIVISOR MS BYTE | | | 0127 7401 | 176 | | MOV | A,#1 ;ADD 1 TO QUOTIENT | | | 0129 2E | 177 | | ADD | A,R6 | | | 012A FE | 178 | | MOV | R6, A continue to the | | | 012B EF | 179 | | MOV | A, R7 | | | 012C 3400 | 180 | | ADDC | A, #0 | | | 012E FF | 181 | | MOV | R7, A | | | 012F C3 | 182 | | CLR | C ;SUBTRACT DIVISOR FROM DIVIDEND | | | 0130 E530 | 183 | | MOV | A, 30H | | | 0130 E530 | | | | | | | | 184 | | SUBB | A, 2DH | | | 0134 F530 | 185 | | VOM | 30H, A | | | 0136 E52F | 186 | | MOV | A,2FH | | | 0138 952C | 187 | | SUBB | A, 2CH | | | 013A F52F | 188 | | MOV | 2FH,A | | | 013C E52E | 189 | | MOV | A, 2EH | | | 013E 952B | 190 | | SUBB | A, 2BH | | | 0140 F52E | 191 | | MOV | 2EH, A | | | 0142 DCC7 | 192 | ZERO: | DJNZ | R4,DIV24 | | | 0144 22 | 193 | | RET | | | | 0145 | 194 | PROG3: | | | | | | 195 | ; | | | | | | 196 | ; | | DISPLAY AVERAGE OF FOUR NEW READINGS | | | | 197 | | | | | | | | , mb. | ic rout | no roads the period of the MO input four times the distance in | _ | | | 198 | | | ne reads the period of the TO input four times, then displays th | ie | | | 199 | | peed" C | rresponding to the average of these four readings. | | | | | ; | | -4 No. | | | 0145 5000 | 200 | | | R1,#3 ;SET FOR 3 READINGS | | | 0145 7903 | 201 | | MOV | | | | 0147 7820 | 201<br>202 | | MOV | RO,#20H ;SET INDEX REGISTER FOR BOTTOM | | | 0147 7820<br>0149 1182 | 201<br>202<br>203 | P30: | MOV<br>ACALL | RO,#20H ;SET INDEX REGISTER FOR BOTTOM MEAS ;TAKE 3 READINGS AND SAVE THEM | | | 0147 7820<br>0149 1182<br>014B EB | 201<br>202 | P30: | MOV | RO,#20H ;SET INDEX REGISTER FOR BOTTOM | | | 0147 7820<br>0149 1182<br>014B EB<br>014C F6 | 201<br>202<br>203 | P30: | MOV<br>ACALL | RO,#20H ;SET INDEX REGISTER FOR BOTTOM MEAS ;TAKE 3 READINGS AND SAVE THEM | | | 0147 7820<br>0149 1182<br>014B EB | 201<br>202<br>203<br>204 | P30: | MOV<br>ACALL<br>MOV | RO, #20H ;SET INDEX REGISTER FOR BOTTOM MEAS ;TAKE 3 READINGS AND SAVE THEM A,R3 | | AN426 | 0150 08 | 208 | | INC | R0 | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0151 A68A | 209 | | MOV | @RO,TL | | | 0153 08 | 210 | | INC | RO RO | | | 0154 D9F3 | | | | | | | | 211 | | DJNZ | R1, P30 | matter 2. Amyr page 1. | | 0156 1182 | 212 | | ACALL | MEAS | ;TAKE A 4TH READING, LEAVING IN R3,TH,TL | | 0158 7828 | 213 | | MOV | RO,#28H | ;SET INDEX REGISTER FOR TOP | | 015A 7903 | 214 | | MOV | R1,#3 | ;SET COUNTER TO ADD FIRST 3 READINGS TO LAST ONE | | 015C E58A | 215 | P31: | MOV | A,TL | ; ADD FIRST THREE READINGS TO THE LAST ONE | | 015E 26 | 216 | | ADD | A, @RO | | | 015F F58A | 217 | | MOV | TL,A | | | 0161 18 | 218 | | DEC | RO | | | 0162 E58C | 219 | | MOV | A, TH | | | 0164 36 | 220 | | ADDC | A, @RO | | | 0165 F58C | 221 | | MOV | | | | 0167 18 | | | | TH, A | | | | 222 | | DEC | RO | | | 0168 EB | 223 | | MOV | A, R3 | | | 0169 36 | 224 | | ADDC | A,@R0 | | | 016A FB | 225 | | MOV | R3,A | | | 016B 18 | 226 | | DEC | R0 | | | 016C D9EE | 227 | | DJNZ | R1,P31 | | | 016E 7902 | 228 | | MOV | R1,#2 | | | 0170 EB | 229 | P32: | MOV | A,R3 | ;DIVIDE BY 4 (ROTATE RIGHT TWICE) FOR AVERAGE | | 0171 C3 | 230 | | CLR | С | / | | 0172 13 | 231 | | RRC | A | | | 0172 IS<br>0173 FB | 232 | | MOV | | | | | | | | R3,A | | | 0174 E58C | 233 | | MOV | A, TH | | | 0176 13 | 234 | | RRC | A | | | 0177 F58C | 235 | | MOV | TH,A | | | 0179 E58A | 236 | | VOM | A,TL | | | 017B 13 | 237 | | RRC | A | | | 017C F58A | 238 | | MOV | TL,A | | | 017E D9F0 | 239 | | DJNZ | R1, P32 | | | 0180 11C5 | 240 | | ACALL | CALC | ;CALCULATE THE WORD | | 0182 51B5 | 241 | | ACALL | SENDIT | ;SEND OUT THE WORD | | | | | | | | | 0184 0140 | 242 | | | | | | 0184 0140 | 242 | DPOC4 | AJMP | READY | ;GO TO SELECTED ROUTINE | | 0184 0140<br>0186 | 243 | PROG4: | | | | | | 243<br>244 | <b>;</b> | AJMP | READY | ;GO TO SELECTED ROUTINE | | | 243<br>244<br>245 | ;<br>; | AJMP | READY | | | | 243<br>244<br>245<br>246 | ;<br>;<br>; | AJMP<br>DISPI | READY LAY AVERAGE OF LAS | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | | 243<br>244<br>245 | ;<br>;<br>; | AJMP<br>DISPI | READY LAY AVERAGE OF LAS | ;GO TO SELECTED ROUTINE | | | 243<br>244<br>245<br>246 | ;<br>;<br>; | AJMP<br>DISPI | READY LAY AVERAGE OF LAS | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | | 243<br>244<br>245<br>246<br>247 | ;<br>;<br>;<br>; Thi | AJMP<br>DISPI | READY LAY AVERAGE OF LAS | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | 0186 | 243<br>244<br>245<br>246<br>247<br>248 | ;<br>;<br>;<br>; Thi | AJMP DISP | READY LAY AVERAGE OF LAS | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | 0186 | 243<br>244<br>245<br>246<br>247<br>248<br>249 | ;<br>;<br>; Thi<br>; | AJMP DISPI s rout: | READY LAY AVERAGE OF LAS ine sends out the RO,#27H | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | 0186 7827<br>0188 7600<br>018A 18 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251 | ;<br>;<br>; Thi<br>; | AJMP DISPI s rout: MOV MOV DEC | READY LAY AVERAGE OF LASsine sends out the RO,#27H GRO,#0 RO | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252 | ;<br>;<br>; Thi<br>; | AJMP DISPI S rout: MOV MOV DEC CJNE | READY LAY AVERAGE OF LASsine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. | | 0186<br>0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254 | ;<br>;<br>; Thi<br>; | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL | READY LAY AVERAGE OF LASS line sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255 | ;;; Thi;; P4: | AJMP DISPL S rout: MOV MOV DEC CJNE MOV ACALL ACALL | READY LAY AVERAGE OF LASsine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL ACALL MOV MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL ACALL MOV MOV INC | READY LAY AVERAGE OF LASS line sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08<br>0197 EE | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258<br>259 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL ACALL MOV MOV INC MOV | READY LAY AVERAGE OF LASsine sends out the RO,#27H @RO,#0 RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08<br>0197 EE<br>0198 F6 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL ACALL MOV MOV INC | READY LAY AVERAGE OF LASS line sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08<br>0197 EE | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258<br>259 | ;;; Thi;; P4: | AJMP DISPI S rout: MOV MOV DEC CJNE MOV ACALL ACALL MOV MOV MOV INC MOV | READY LAY AVERAGE OF LASsine sends out the RO,#27H @RO,#0 RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08<br>0197 EE<br>0198 F6 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258<br>259<br>260 | ;;; Thi;; P4: | DISPI<br>MOV<br>MOV<br>DEC<br>CJNE<br>MOV<br>ACALL<br>ACALL<br>MOV<br>MOV<br>INC<br>MOV<br>MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE | | 0186<br>0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08<br>0197 EE<br>0198 F6<br>0199 752800 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258<br>260<br>261 | ;;; Thi;; P4: | MOV MOV ACALL ACALL MOV MOV ACALL ACALL MOV MOV INC MOV MOV MOV MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO A,R6 GRO,A 28H,#0 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE | | 0186 7827<br>0188 7600<br>018A 18<br>018B B81FFA<br>018E 7820<br>0190 1182<br>0192 11C5<br>0194 EF<br>0195 F6<br>0196 08<br>0197 EE<br>0198 F6<br>0199 752800<br>019C 752900 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258<br>259<br>260<br>261<br>262<br>263 | ;; Thi;; P4: | MOV MOV ACALL ACALL MOV MOV MOV ACALL MOV MOV MOV MOV MOV MOV MOV MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>260<br>261<br>262<br>263<br>264 | ;;; Thi;; P4: | MOV MOV MOV MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>258<br>260<br>261<br>262<br>263<br>264<br>265 | ;; Thi;; P4: | MOV MOV ACALL MOV MOV ACALL MOV MOV INC MOV MOV MOV MOV MOV MOV MOV CLR | READY LAY AVERAGE OF LASS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>261<br>262<br>263<br>264<br>265<br>265<br>266 | ;; Thi;; P4: | MOV MOV ACALL ACALL MOV MOV MOV ACALL ACALL MOV | READY LAY AVERAGE OF LASS line sends out the RO,#27H GRO,#0 RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO A,R6 GRO,A 28H,#0 29H,#0 RI,#27H A,29H C A,GR1 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 | 243<br>244<br>245<br>246<br>247<br>248<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>257<br>260<br>261<br>262<br>263<br>264<br>265<br>266<br>267 | ;; Thi;; P4: | DISPI S FOUL: MOV MOV DEC CJNE MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 20H,#0 R1,#27H A,29H C A,@R1 29H,A | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 | 243<br>244<br>245<br>246<br>247<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>257<br>258<br>259<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>268 | ;; Thi;; P4: | MOV MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO A,R6 GRO,A 28H,#0 29H,#0 R1,#27H A,29H C A,GR1 29H,A A,28H | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>260<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>268<br>269 | ;; Thi;; P4: | MOV MOV ACALL MOV MOV ACALL MOV MOV INC MOV | READY LAY AVERAGE OF LASS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C A, @R1 29H,A A,28H R1 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AA 37 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>266<br>267<br>268<br>269<br>270 | ;; Thi;; P4: | MOV MOV MOV MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C A,@R1 29H,A A,28H R1 A,@R1 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AA 37 01AB F528 | 243<br>244<br>245<br>246<br>247<br>249<br>250<br>251<br>252<br>253<br>254<br>255<br>257<br>258<br>260<br>261<br>262<br>263<br>264<br>265<br>267<br>268<br>267<br>268<br>270<br>271 | ;; Thi;; P4: | MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C A,@R1 29H,A A,28H R1 A,@R1 28H,A | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 752290 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AA 37 01AB F528 01AD 19 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>268<br>269<br>271<br>272 | ;; Thi;; P4: | MOV MOV MOV MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO A,R6 GRO,A 28H,#0 29H,#0 CA,82H CA,871 A,29H CA,681 A,29H R1 A,681 A,881 A,881 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AA 37 01AB F528 01AD 19 01AB B91FF0 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>268<br>269<br>270<br>271<br>272 | ;; Thi;; P4: | MOV MOV MOV ACALL MOV | READY LAY AVERAGE OF LASS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C A,@R1 29H,A A,28H R1 A,@R1 28H,A R1 R1,#1FH,P41 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AB F528 01AD 19 01AE B91FF0 01B1 7902 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>268<br>269<br>271<br>272 | ;; Thi;; P4: | MOV MOV MOV MOV ACALL ACALL MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H GRO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 GRO,A RO A,R6 GRO,A 28H,#0 29H,#0 CA,82H CA,871 A,29H CA,681 A,29H R1 A,681 A,881 A,881 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019F 752800 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AA 37 01AB F528 01AD 19 01AB B91FF0 01B1 7902 01B3 C3 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>256<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>268<br>269<br>270<br>271<br>272 | ;; Thi;; P4: | MOV MOV MOV ACALL MOV | READY LAY AVERAGE OF LASS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C A,@R1 29H,A A,28H R1 A,@R1 28H,A R1 R1,#1FH,P41 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | | 0186 0186 7827 0188 7600 018A 18 018B B81FFA 018E 7820 0190 1182 0192 11C5 0194 EF 0195 F6 0196 08 0197 EE 0198 F6 0199 752800 019C 752900 019F 7927 01A1 E529 01A3 C3 01A4 27 01A5 F529 01A7 E528 01A9 19 01AB F528 01AD 19 01AE B91FF0 01B1 7902 | 243<br>244<br>245<br>246<br>247<br>248<br>250<br>251<br>252<br>253<br>254<br>255<br>266<br>261<br>262<br>263<br>264<br>265<br>266<br>267<br>266<br>270<br>271<br>273<br>274 | ;; Thi; P4: P4A: P4O: | MOV | READY LAY AVERAGE OF LAS ine sends out the RO,#27H @RO,#0 RO RO,#1FH,P4 RO,#20H MEAS CALC A,R7 @RO,A RO A,R6 @RO,A 28H,#0 29H,#0 R1,#27H A,29H C A,@R1 29H,A A,28H R1 A,@R1 28H,A R1 R1 R1,#1FH,P41 R1,#2 | ;GO TO SELECTED ROUTINE T FOUR WORDS SENT OUT average of the last four readings sent out. ;MEASURE PERIOD ;CALCULATE THE CODE ;SAVE THE CODE ;INITIALIZE THE WORD TO SEND | January 1992 428 AN426 ``` 01B6 13 277 RRC 01B7 F528 278 MOV 28H, A A, 29H 01B9 E529 279 MOV 01BB 13 280 RRC 29H, A MOV 01BC F529 281 01BE D9F3 282 DJNZ R1, P42 R7,28H 01C0 AF28 283 VOM 01C2 AE29 284 MOV R6,29H ; SEND OUT THE WORD 01C4 51B5 285 ACALL SENDIT ACALL ; READ PROGRAM SELECT 01C6 51D2 286 RPS ;JUMP TO N4 (& "READY") IF PROGRAM 4 NOT SELECTED 01C8 B40806 287 CJNE A, #8, N4 TNC RΩ 01CB 08 288 ;GOTO P40 IF R0 NOT 28 (HEX) 01CC B828C1 CJNE RO, #28H, P40 289 01CF 80BD SITMP P4A 290 01D1 0140 291 N4: AJMP READY 292 293 PROG5: 294 This routine advances the display in 45 degree steps to full scale, then steps down 295 ; to zero in 45 degree steps. There is a 500ms delay between steps. 296 297 ; 01D3 7F00 298 MOV R7,#0 01D5 7E7F 299 P5: MOV R6,#07FH ; SEND THE WORD AND WAIT 500ms 01D7 51B1 300 ACALL SD500 01D9 7EFF MOV R6,#0FFH 301 ; SEND THE WORD AND WAIT 500ms 01DB 51B1 302 ACALL SD500 01DD OF TNC R7 303 01DE BF04F4 304 CJNE R7, #4, P5 01E1 7F03 305 VOM R7,#3 01E3 7EFF R6,#0FFH 306 LP5: :SEND THE WORD AND WAIT 500ms 01E5 51B1 ACALL SD500 307 R6,#7FH 01E7 7E7F 308 MOV 01E9 51B1 SD500 309 ACALL 01EB 1F 310 DEC 01EC BFFFF4 311 CJNE R7, #0FFH, LP5 ; RETURN TO ZERO 01EF 511B 312 ACALL ZEROSC :WAIT FOR KEY PRESS 01F1 013D 313 AJMP PROG6: 01F3 314 315 This routine advances the display in 90 degree steps to full scale, then steps down 316 317 ; to zero in 90 degree steps. There is a 500ms delay between steps. 318 01F3 7EFF 319 MOV R6,#0FFH MOV R7,#0 01F5 7F00 320 01F7 51B1 ACALL SD500 ; SEND THE WORD AND WAIT 500ms 321 LP6: 01F9 OF R7 322 INC R7, #4, LP6 01FA BF04FA 323 CJNE 01FD 1F 324 LP6A: DEC R7 ; SEND THE WORD AND WAIT 500ms 01FE 51B1 325 ACALL SD500 0200 BF00FA 326 CJNE R7,#0,LP6A 0203 511B ; RETURN TO ZERO ACALL ZEROSC 327 0205 013D :WAIT FOR KEY PRESS 328 AJMP PROG7: 0207 329 330 ; This routine alternates between 3/8 and 5/8 scale ten times with 300ms delay 331 332 between steps, then waits 500ms before returning display to zero scale. 333 R2,#10 0207 7A0A 334 MOV :SET COUNTER 0209 7E7F 335 PR7: MOV R6,#07FH 020B 7F01 MOV R7,#1 336 020D 51AD 337 ACALL SD300 ; SEND OUT THE WORD AND WAIT 300ms 020F 7F02 MOV R7.#2 338 0211 51AD ACALL SD300 ; SEND OUT THE WORD AND WAIT 300ms 339 ;DO IT 10 TIMES R2,PR7 0213 DAF4 DJNZ 340 ACALL DLY500 ;WAIT 500ms 0215 51A5 341 ; RESET TO ZERO SCALE 0217 511B 342 ACALL ZEROSC ;LOOK FOR VALID PROGRAM 0219 0130 343 AJMP START 344 345 ; ``` 429 AN426 ``` 346 SUBROUTINES 347 ; 348 021B 7F00 ZEROSC: MOV 349 R7,#0 ; RESET METER TO ZERO SCALE 021D 7E00 350 MOV R6,#0 021F 4125 351 AJMP RST 0221 7F03 352 FULLSC: MOV R7,#03H ; SET METER TO FULL SCALE 0223 7EFF 353 VOM R6,#0FFH 0225 51B5 354 RST: ACALL SENDIT 0227 22 355 0228 356 SO: 357 358 ; This subroutine sends increasing 10-bit words in registers R7 & R6 to the ACMD. 359 0228 51B5 360 ACALL SENDIT ;WRITE THE 10-BIT WORD TO ACMD 022A 5130 361 ACALL UP ; INCREASE THE WORD VALUE 022C 30E2F9 362 JNB ACC.2,SO ;JUMP IF BIT 2 NOT SET 022F 22 363 0230 UP: 364 365 366 This subroutine waits for a period of time = 10ms X DELAY read un, then increases the 10-bit word by the INCREMENT SELECT amount. 367 368 0230 E590 369 MOV A, P1 ; READ DELEY 0232 F4 370 CPL ; COMPLEMENT ACC 0233 540F 371 ANL A.#OFH ; MASK OFF UPPER 4 BITS 0235 23 372 RL Α 0236 23 373 RT. Α 0237 F9 374 VOM R1,A 0238 B90002 375 CJNE R1,#0,D10 ;JUMP IF DELAY SET FOR ZERO 023B 8006 376 SJMP NODLY 023D 7B01 377 D10: MOV R3,#1 ;SET FOR 1 X 10ms DELAY 023F 5195 378 D10A: ACALL DLY10MS ; DELAY 10MS x DELAY 0241 D9FC 379 DJNZ R1,D10A 0243 E5B0 380 NODLY: MOV A, P3 ; READ INCREMENT SELECT 0245 F4 381 CPL Α ; COMPLEMENT ACC 0246 5403 382 ANL A,#3 ; MASK OFF UPPER 6 BITS 0248 23 383 RL Α 0249 23 384 RL Α 024A 23 385 RL 024B 04 386 TNC 024C 2E 387 ADD A,R6 ; ADD INCREMENT TO R6 024D FE 388 MOV R6,A ; SAVE IT 024E E4 389 CLR Α 024F 3F 390 ADDC A,R7 ; ADD CARRY TO R7 0250 FF 391 MOV R7,A ; SAVE IT 0251 22 392 RET 0252 393 SOD: 394 395 This subroutine sends out decreasing words at the rate set by DELAY and 396 step size determined by INCREMENT SELECT. 397 0252 51B5 398 ACALL SENDIT ; SEND OUT THE PRESENT WORD 0254 515A 399 ACALL DOWN ; DECREASE THE WORD 0256 50FA 400 JNC SOD ;DO IT AGAIN IF CARRY NOT SET 0258 411B 401 AJMP ZEROSC 025A 402 DOWN: 403 ; Waits for 10ms x DELAY pot setting, then sends out decreasing values of words 404 405 in step sizes of 8 x INCREMENT SELECT + 1. 406 025A E590 407 MOV A, P1 ; READ DELAY 025C F4 408 CPL Α ; COMPLEMENT ACC 025D 540F 409 ANL A, #OFH ; MASK OFF UPPER FOUR BITS 025F 23 410 RL Α 0260 23 411 RL 0261 F9 412 MOV R1,A ; SAVE DELAY 0262 B90002 413 CJNE R1,#0,D10S ; JUMP IF DELAY SET FOR ZERO 0265 8004 SJMP NDD ``` ``` D10S: ACALL DLY10MS ; DELAY 10ms x (DELAY +1) 0267 5195 415 0269 D9FC 416 DJNZ R1, D10S 417 A, P3 ; READ INCREMENT SELECT 026B E5B0 NDD: MOV ; COMPLEMENT ACC Α 026D F4 418 ; MASK OFF UPPER 6 BITS A.#3 026E 5403 ANL 419 ; MULTIPLY BY 8 0270 23 420 RL Α 0271 23 421 RL Α 0272 23 422 RL :INSURE MINIMUM STEP 0273 04 423 INC ;CLEAR CARRY FOR SUBTRACTION 0274 C3 424 CLR 0275 CE 425 XCH A,R6 ; SUBTRACT INCREMENT FROM R6 0276 9E A,R6 426 SUBB ; SAVE IT 0277 CE 427 XCH A,R6 ;CLEAR ACCUM FOR SUBTRACTION 0278 E4 428 CLR Α A,R7 0279 CF 429 XCH A, R7 ; SUBTRACT BORROW FROM R7 027A 9F SUBB 430 ; INSURE MAXIMUM WORD 027B 5403 A,#3 431 XCH A,R7 ; SAVE IT 027D CF 432 027E 22 433 RET 027F 00 ;30s DELAY 434 DELAY: NOP 0280 22 435 RET 0281 436 DMS10: 437 Produces a delay of 10ms x the value in R3. 438 439 Destroys R3 and timer readings. ; 440 441 TL, #LOW, (0-10000) ; LOAD TIMER FOR 10ms DELAY 0281 758AF0 442 MOV 0284 758CD8 TH, #HIGH(0-10000) 443 MOV ;CLEAR TIMER FLAG 0287 C28D CLR TF 444 SETB TR ;START TIMER 0289 D280 445 ; WAIT FOR TIMER FLAG TO BE SET MS10W: JNB TF, MS10W 028B 308DFD 446 028E C28D TF ;CLEAR TIMER FLAG CLR 447 ;WAIT RS x 10ms DJNZ R3,MS10W 0290 DBF9 448 тR :STOP TIMER 0292 C28C 449 CLR 0294 22 450 RET 451 0295 7B01 DLY10MS: MOV R3,#1 ; SET R3 FOR 10ms WAIT 452 DMS10 ;WAIT 10ms 0297 80EB 453 SJMP 454 DLY100: MOV R3.#10 ;SET R3 FOR 100ms WAIT 0299 7B0A 455 SJMP DMS10 ;WAIT 100ms 029B 80E4 456 457 DLY200: MOV R3,#20 ;SET R3 FOR 200ms WAIT 029D 7B14 458 029F 80E0 SJMP DMS10 ;WAIT 200ms 459 460 ;SET R3 FOR 300ms WAIT DLY300: MOV R3,#30 02A1 7B1E 461 ;WAIT 300ms SITMP DMS10 02A3 80DC 462 463 ;SET R3 FOR 500ms WAIT DLY500: MOV R3.#50 02A5 7B32 464 02A7 80D8 SJMP DMS10 ;WAIT 500ms 465 466 SD200: ACALL SENDIT ; SEND THE WORD 02A9 51B5 467 ;WAIT 200ms 02AB 80F0 468 SJMP DLY200 469 ; SEND THE WORD 02AD 51B5 470 SD300: ACALL SENDIT 02AF 80F0 SJMP DLY300 ;WAIT 200ms 471 472 ; SEND THE WORD 02B1 51B5 SD500: ACALL SENDIT 473 ;WAIT 500ms 02B3 80F0 474 SJMP 475 02B5 476 SENDIT: 477 478 This subroutine sends out a single word locate4d in R7 and R6. Accumulator, R0 and R1 are destroyed. 479 480 ; SET CS HIGH 02B5 D282 481 SETB P0.2 ;SET COUNTER FOR 2 BITS OF R7 R1,#02 02B7 7902 482 MOV 02B9 EF 483 MOV A, R7 ; MOVE R7 TO A FOR SEND OUT ``` 431 ### Controlling air core meters with the 87C751 and SA5775 AN426 ``` 02BA 13 484 RRC Α ;ALIGN R7 FOR SEND OUT 02BB 13 485 RRC Α 02BC 13 486 RRC 02BD 51C7 487 ACALL SEND1 ; SEND OUT UPPER TWO BITS 02BF 7908 488 R1,#8 ;SET COUNTER FOR R6 SEND OUT 02C1 EE 489 MOV A,R6 ; MOVE R6 TO ACCUM 02C2 51C7 490 ACALL SEND1 ;SEND OUT LOWER 8 BITS 02C4 C282 491 CLR P0.2 ;LOAD ACMD 02C6 22 492 RET 02C7 493 SEND1: 494 This subroutine sends [R1] number of bits of the accumulator, starting 495 496 with the MSB over the IIC port. 497 Accumulator, R0 and R1 are destroyed. 498 02C7 33 499 RLC ; ROTATE BIT TO CARRY 02C8 9281 500 MOV P0.1,C ; MOVE CARRY TO DATA OUT 02CA C280 501 CLR P0.0 ;CLOCK LOW 02CC 00 502 NOP 02CD D280 503 SETB P0.0 ;CLOCK HIGH 02CF D9F6 504 DJNZ ; SEND NEXT BIT TILL DONE R1,SEND1 02D1 22 505 RET 506 02D2 E5B0 507 RPS: MOV A, P3 ; READ PORT 3 FOR PROGRAM SELECT 02D4 F4 508 CPL Α ; COMPLEMENT ACC 02D5 03 509 RR Α ; ROTATE TO LSB's & MULT BY 2 02D6 540E 510 ANL A,#0EH ; MASK FOR PROGRAM SELECT * 2 02D8 DD 511 RET 512 END ``` ASSEMBLY COMPLETE, 0 ERRORS FOUND # Controlling air core meters with the 87C751 and SA5775 | במכל ה | 00E0H | PREDEFINED | |--------------------------------------------|----------------|--------------------------| | ACC D ADDR CALC C ADDR | 00C5H | | | D10 C ADDR | 023DH | | | DIOA C ADDR | 023FH | | | D10S C ADDR | 0267H<br>0073H | | | DELAY C ADDR | 027FH | NOT USED | | DIV24 C ADDR | 010BH | NOT USED | | DLY100 C ADDR<br>DLY10MS C ADDR | 0299H<br>0295H | NOT USED | | DLY10MS C ADDR<br>DLY200 C ADDR | 029DH | | | DLY300 C ADDR | 02A1H | | | DLY500 C ADDR | 02A5H<br>0281H | | | DMS10 C ADDR DOWN C ADDR | 025AH | | | DP1 C ADDR | 006DH | | | FULLSC C ADDR | 0221H<br>00C0H | | | GFS C ADDR GZS C ADDR | 00BDH | | | HT C ADDR | 00B7H | | | IE D ADDR | 00A8H | PREDEFINED | | JMPTBL C ADDR | 004CH<br>01E3H | | | LP5 C ADDR | 01F7H | | | LP6A C ADDR | 01FDH | | | LP6A C ADDR<br>MEAS C ADDR<br>MS10W C ADDR | 0082H<br>028BH | | | MS10W C ADDR | 01D1H | | | NDD C ADDR | 026BH | | | NODLY C ADDR | 0243H | | | NZS C ADDR | 00B0H | PREDEFINED | | P0 D ADDR<br>P1 D ADDR | 0090H | PREDEFINED | | P3 D ADDR | 00В0Н | PREDEFINED | | P30 C ADDR<br>P31 C ADDR | 0149H<br>015CH | | | P31 C ADDR<br>P32 C ADDR | 0170H | | | P4 C ADDR | 0188H | | | P40 C ADDR | 0190H<br>01A1H | | | P41 C ADDR<br>P42 C ADDR | 01B3H | | | P4A C ADDR | 018EH | | | P5 | 01D5H<br>0209H | | | PROGO C ADDR | 005CH | | | PROG1 C ADDR | 0068Н | | | PROG2 C ADDR PROG3 C ADDR | 007AH<br>0145H | | | PROG3 C ADDR PROG4 C ADDR | 0186H | | | PROG5 C ADDR | 01D3H | | | PROG6 C ADDR<br>PROG7 C ADDR | 01F3H<br>0207H | | | READY C ADDR | 0040H | | | ROTT C ADDR | 00F0H | | | RPS C ADDR | 02D2H<br>0225H | | | RST C ADDR RTH D ADDR | 008DH | PREDEFINED | | RTL D ADDR | | PREDEFINED | | SD200 C ADDR<br>SD300 C ADDR | 02A9H<br>02ADH | NOT USED | | SD300 C ADDR<br>SD500 C ADDR | 02B1H | | | SEND1 C ADDR | 02C7H | | | SENDIT C ADDR | 02B5H<br>0228H | | | SO C ADDR | 0252H | | | START C ADDR | | · | | TF B ADDR | | PREDEFINED<br>PREDEFINED | | TH D ADDR | 008CH<br>008AH | PREDEFINED | | TR B ADDR | 008CH | PREDEFINED | | UP C ADDR | | | | W C ADDR<br>W20 C ADDR | | | | W20 C ADDR<br>W21 C ADDR | | | | W22 C ADDR | HDA00 | | | W23 C ADDR | | | | ZERO C ADDR<br>ZEROSC C ADDR | | | | ZLINOBE C REDIN | | | AN427 The small package 83/87C748, 83/87C749, 83/87C751 and 83/87C752 microcontrollers include two hardware-implemented timers: a 16-bit programmable timer, and a 10-bit fixed-rate timer. The programmable timer is available for the application program, and its operation is similar to the timer/counter of the 80C51 timer in mode 2. The fixed-rate timer, Timer I, is typically employed as a watchdog timer for the I<sup>2</sup>C port communications and is not available for other uses. In applications which do not take advantage of the I<sup>2</sup>C communications capability, the "silicon real estate" taken by Timer I is not necessarily lost—it can be used as a fixed-rate timer by the application. This timer can become useful in various cases, such as simple control applications that need a delay while doing some software activities in parallel, or generating a free-running repetitive waveform where the exact timing is not important. Another type of application is a watchdog timer prompting the user about unexpected operation of a system or its hardware, or resetting a program that "lost track." ### TIMER I IMPLEMENTATION Timer I is clocked once per machine cycle, which is the oscillator frequency divided by 12. The timer operation is enabled by setting the TIRUN bit (bit 4) in the I2CFG register. Writing a 0 into the TIRUN bit will stop and clear the timer. The timer is 10 bits wide, and when it reaches the terminal count of 1024 it carries out and sets the Timer I interrupt flag. An interrupt will occur if the Timer I interrupt is enabled by bit ETI (bit 4) of the Interrupt Enable (IE) register, and global interrupts are enabled by bit EA (bit 7) of the same IE register. The vector address for the Timer I interrupt is 1B hex, and the interrupt service routine must start at this address. As with all 8051 family microcontrollers, only the Program Counter is pushed onto the stack upon interrupt (other registers that are used both by the interrupt service routine and elsewhere must be explicitly saved). The Timer I interrupt flag is cleared by setting the CLRTI bit (bit 5) of the I2CFG register. Note that when the I<sup>2</sup>C interface is not operating—SLAVEN, MASTRQ, and MASTER bits are all 0—the I<sup>2</sup>C hardware does not affect Timer I. The SCL and SDA pins can be used as I/O pins, and the activity of these pins will not cause the timer to run, stop, or reset. Upon hardware reset of the microcontroller, the SLAVEN, MASTRQ, and MASTER bits are all reset, so the programmer does not have to worry about interaction between the SDA/SCL pins and the timer. ### **FIXED-RATE TIMER** The first programming example demonstrates simple fixed-rate operation. Upon reset, interrupts are enabled, and Timer I is started. A wait loop simulates the "application" program. The demonstration service routine simply sets a flag-in real life it could do something more useful, such as toggling an output pin. Note that the interrupt flag is cleared by setting CLRTI prior to returning from the service routine. Upon overflow, the timer will go on running, as the TIRUN bit is still set, so the interrupts will be spaced exactly 1024 clock cycles apart. If the service routine would toggle an output pin instead of setting a flag, its output would be a square wave with a period of 2048 cycles. For an application that demands a "one-shot" delay only, the service routine should clear the TIRUN bit in order to avoid subsequent interrupts. ### **WATCHDOG TIMER** A watchdog timer mechanism is typically applied in order to detect "abnormal" behavior of hardware. If the microcontroller operates in a very noisy environment, there might be a fear of the program "running wild" as a result of extremely violent EMI interference. In such a case, a watchdog may take care to reset the microcontroller when the Timer I interrupt occurs. This could be applied in application programs with a repetitive nature—the software needs to reset the timer within 1024 machine cycles of the last reset. In a system where something is supposed to occur regularly—for example, an interrupt for an external event—the watchdog is designed to "bite" when the hardware "sleeps" and the expected "something" does not happen for too long a time. The timer is allowed to run continuously, but when the expected event occurs, it resets the timer back to 0. When the timer is reset within 1024 cycles of the last reset, the application runs normally. If the event does not occur, the Timer I interrupt service routine will be activated to take care of the exception. The second programming example demonstrates the watchdog. Upon Reset, the TIRUN bit, ETI, and global interrupts are enabled. The watchdog timer is reset and restarted by the small subroutine WdRst. The application is simulated by a loop of delays. Delay 1 is less than 1024 cycles, and when WdRst is called within Delay 1 intervals, no Timer I interrupt occurs. This represents normal operation of a "real life" application. When the delay from last reset is greater than 1024 cycles—representing a hardware exception-the interrupt will occur. The service routine for the watchdog is somewhat unusual, as it does not return to the program location where the interrupt occurred. Instead, the operation of the microcontroller is restarted at Reset. Upon entering the service routine, the interrupt is cleared and the timer is reset. Because execution does not return to the interrupted program with a RETI instruction, the interrupt pending flag is cleared by a call to a dummy subroutine XRETI. The program is restarted at Reset with a regular AJMP instruction. The stack pointer is explicitly reinitialized for the warm reset, so there is no danger of stack overflow upon repeated watchdog invocations. AN427 TIINT Timer I Fixed Rate Timer 11/06/90 PAGE 1 ``` ********* Timer I Fixed Rate Timer Usage 5 ; This program demonstrates how to activate Timer I on the 8XC748/8XC749/83C751 6 ;or 83C752 microcontrollers as a fixed rate timer when the I2C port is not 7 ;used. Once activated, Timer I will generate an interrupt every 1024 8 ; machine cycles. The I2C bus pins SCL and SDA may be used as open drain 9 ;outputs. 10 11; ****************** 12 13 $MOD7 751 $Title(Timer I Fixed Rate Timer) 15 $Date(11/06/90) $Debug 16 17 18 DATA 20h ;Flag byte 0020 19 Flags Flags.0 ;Timer I flag. 0000 TstFlag BIT 21 22 ORG 0000 23 Reset AJMP 0000 0120 24 25 ;Timer I interrupt. 001B 26 ORG 1Bh ;Set flag to indicate a Timer I interrupt. 001B D200 TimerI: SETB TstFlag 2.7 ;Clear Timer I to allow it to restart. SETB CLRTI 001D D2DD 001F 32 28 29 RETT 30 31 ;Enable Timer I interrupt. ;Enable global interrupts. SETB ETI 0020 D2AB 32 Reset: SETB EA 0022 D2AF 33 ;Start Timer I. SETB TIRUN 0024 D2DC 34 35 ; Initialize interrupt flag. 0026 C200 0028 3000FD CLR TstFlag 36 Loop: TstFlag, Wait ; Wait for Timer I interrupt. JNB 37 Wait: SJMP Loop 002B 80F9 38 39 END 40 ``` ASSEMBLY COMPLETE, 0 ERRORS FOUND | TIINT | Timer I Fixed Rate Timer | 11/06/90 PAGE 2 | |------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------| | CLRTI. EA . ETI. FLAGS. LOOP RESET. TIMERI TIRUN. TSTFLAG. | B ADDR 00AFH PREDEFINED B ADDR 00ABH PREDEFINED D ADDR 0020H C ADDR 0020H C ADDR 001BH NOT USED B ADDR 001CH PREDEFINED | | AN427 PAGE 1 11-06-90 Timer I Watchdog TIWD Timer I Watchdog Timer Usage 3; 5 ; This program demonstrates how to use Timer I on the 83C751 or 83C752 6 ;microcontrollers as a watchdog timer when the I2C port is not used. 7 ;Once started, Timer I must be cleared more often than once every 1024 8 ;machine cycles. If Timer I is allowed to overflow, a Timer I 9 ;interrupt will be generated. Thus, if global interrupts or the Timer 10 ;I interrupt are inhibited, the watchdog function will be disabled. 11 ;Also, if the watchdog interrupt occurs during another interrupt 12 ; service, it will be delayed until an RETI (return from interrupt) ; instruction is executed. The I2C bus pins SCL and SDA may be used as 14 ; open drain outputs. 17 18 \$Title(Timer I Watchdog) 19 SDate(11-06-90) 20 21 SDebug 0000 ORG 0 23 Reset 0000 0126 24 AJMP 25 ;Timer I interrupt. 1<sub>Bh</sub> ORG 001B 26 EΑ ;Get here only if watchdog overflows. 001B C2AF 27 TimerI: CLR ;Turn off Timer I. TIRUN CLR 001D C2DC 28 ;Clear Timer I interrupt. 001F D2DD 29 SETB CLRTI ; Force interrupt pending to clear. ACALL XRETI 30 0021 1125 ;Do a warm start. AJMP Reset 0023 0126 31 RETT 0025 32 32 XRETI: 33 ;Initialize the stack pointer. SP,#7h 0026 758107 34 Reset: MOV 35 36 ; Note: it is important to force the stack pointer to a particular ; starting value in this application because we may be re-starting ;after a watchdog interrupt, with the stack in an unknown condition. 38 39 ; Initialize I2CFG (set up CT0, CT1). 0029 75D800 I2CFG, #0 40 MOV ; Enable Timer I run. TIRUN SETB 002C D2DC 41 ; Enable Timer I interrupt. 002E D2AB 42 SETB ETT :Enable interrupt system. 0030 D2AF 43 SETB 44 45 46 ; The following is a "dummy" main program to test the watchdog timer. 47 ;Wait 901 machine cycles. 48 ACALL Delav1 0032 1153 Loop: ; Reset Watchdog. 0034 114E 49 ACALL WdRst ;Wait 901 machine cycles. Delay1 0036 1153 0038 114E 50 ACALL ; Reset Watchdog. WdRst 51 ACALL. ; Wait 901 + 4 for ACALL & prior RET. Delay1 003A 1153 52 ACALT. ;Wait 108 + 2 for ACALL. 003C 1157 53 ACALL Delay2 003E 00 54 NOP ;1016 003F 00 55 NOP ;1017 ;1018 NOP 0040 00 56 ;1019 0041 00 57 NOP NOP ;1020 0042 00 AN427 | TIW | D . | | | Timer I | Watchdog | | 11-06-90 | PAGE 2 | |-----------------------------------------------|--------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------|----------|--------| | 004<br>004<br>004<br>004<br>004<br>004<br>004 | 3 00<br>4 00<br>5 00<br>6 00<br>7 00<br>3 00<br>9 00<br>A 00<br>3 00<br>C 0132 | 59<br>60<br>61<br>62<br>63<br>64<br>65<br>66<br>67<br>68 | | NOP ;1021<br>NOP ;1022<br>NOP ;1023<br>NOP ;1024<br>NOP ;1025<br>NOP ;1026<br>NOP ;1027<br>NOP ;1028<br>NOP ;1029<br>AJMP Loop | | : Should get 'bitten' here. | | | | 0050<br>0052 | | 69<br>70<br>71<br>72<br>73 | WdRst: | CLR TIRUN<br>SETB TIRUN<br>RET | | ;Reset Watchdog timer (Timer I). | | | | 0055<br>0057<br>0057<br>0057 | A A3<br>B 14<br>C 70FB | 74<br>75<br>76<br>77<br>78<br>79<br>80<br>81<br>82 | Delay1:<br>Delay2:<br>DLoop: | MOV A,#128 SJMP DLOOP MOV A,#15 INC DPTR INC DPTR DEC A JNZ Dloop RET | 3 | ;Wait 901 machine cycles (1). ;(2) ;Wait 108 machine cycles (1). ;Delay = (ACC * 7) + 2 mach. cyc ;(2) ;(1) ;(2) ;(2) | (2). | | | | | 83 | | END | | | | | ASSEMBLY COMPLETE, 0 ERRORS FOUND AN427 PAGE 3 | TIWD | Tin | ner I Watchdog | 11-06-90 | |--------|--------|------------------|----------| | | | | | | CLRTI | B ADDE | 00DDH PREDEFINED | | | DELAY1 | C ADDE | ₹ 0053Н | | | DELAY2 | C ADDI | | | | | C ADDI | | | | EA | B ADDI | | | | ETI | | | | | | | | | | 12CFG | 0.355 | | | | LOOP | C ADDI | | | | RESET | | | | | SP | D ADDI | | | | TIMERI | C ADDI | | | | TIRUN | B ADD | | | | WDRST | C ADD | | | | XRETT | C ADD | R 0025H | | **AN428** The Philips 83C752/87C752 is a single-chip control-oriented microcontroller. It is an 80C51 derivative, having the same basic architecture and powerful instruction set in a small 28-pin package. As "add-on" functions to a standard microcontroller, it offers an I<sup>2</sup>C small area network port, a five-channel multiplexed 8-bit analog-to-digital converter (ADC), and a pulse width modulation (PWM) output. The part is essentially the popular 8XC751 with the addition of the ADC and the PWM output. There are many control applications for which this microcontroller can provide an almost-complete, low-cost solution. The A/D converter can monitor analog voltages of up to five sources. The PWM output can be used to generate an analog control voltage with the addition of a simple integrator circuit. Another potential use for the PWM output is as a driver of power-switching circuits for DC motor speed control. The analog-to-digital converter has 8-bit resolution, and the conversion takes 40 machine cycles. A multiplexer selects one out of five input pins. The operation of the A/D converter and the multiplexer is controlled by the ADCON register. The repetition frequency of the PWM output pulses is determined by an 8-bit prescaler, programmed at register PWMP. The duty cycle of these pulses is determined by the contents of a compare register, PWM. In order to implement the pulse width modulator, the prescaler output drives an 8-bit counter. When the counter value matches the contents of the compare (PWM) register, the PWM output is set high, and when the counter reaches zero, the output is set low. The counter is modulo 255, so the duty cycle generated will be the PWM contents multiplied by 1/255. The enclosed listing demonstrates usage of the A/D converter and the PWM. In order to communicate with the outside world, the program sends messages on a software-driven RS-232 port. The routines for sending messages via a software-controlled serial port can be quite useful, and for further discussion on those, please refer to Application Note 423: "Software Driven Serial Communication Routines for the 83C751 and 83C752 Microcontrollers." Bit 5 of port 1 is used for the RS-232 communications, and in order to hook the microcontroller to a terminal, a buffer (e.g., MC1488) is needed. Timer 0 is used as the baud rate generator, where the timer value is defined by the symbol BaudVal. The programmed value will generate a 9600 baud rate with a 16MHz crystal. The program, after initialization and sending a message to the terminal, scans all five A/D channel inputs and outputs the voltage read on the serial port, as a hexadecimal value. Circuit operation can be verified by comparing channel voltages with the reading at the terminal. The program follows with an infinite loop in which channel 0 of the A/D converter is read, and its value is used to program the PWM. A simple verification of the duty cycle can be done with a voltmeter: since it acts as an integrator, its reading will be proportional to the duty cycle. Reading of a voltmeter on the PWM output should be proportional to the channel 0 input voltage. If the analog reference voltage $AV_{CC}$ , which is full-scale of the A/D measurement, is set to be exactly as V<sub>CC</sub>, the PWM output will track channel 0 within about 20mV. 1 : ### AN428 DEMO752C 87C752 A/D and PWM Demonstration 12/03/90 PAGE 1 ``` 2 3 4 87C752 A/D and PWM Demonstration Program 5 6 ; This program first reads all five A/D channels and outputs the values in ; hexadecimal as RS-232 data. Next, the PWM output is set to reflect the 8 ; value on A/D channel 0, and again outputs the A/D value to RS-232. Note 9 ; that the A/D value is inverted before being moved to the PWM compare 10 ; register in order to compensate for the inversion on the PWM output pin. 11 12 ; This process is repeated continuously. ; Thus, a voltage may be applied to ADCO (P1.0, pin 13) to vary the PWM pulse ; width. A simple test of this function is to measure the voltage on ADCO ; and PWM with a voltmeter. A typical voltmeter will integrate the waveform ; on the PWM output and show a voltage within about 20mV of that on ADCO. 17 ; The RS-232 output appears on Port 1 pin 5, which must be buffered with an ; MC1488 or perhaps a MAX232 chip prior to being connected to a terminal. The transmission rate will be 9600 baud when the 87C752 is operated from ; 16MHz crystal. 22 23 ****************** 2.4 STitle(87C752 A/D and PWM Demonstration) 27 $Date(12/03/90) 28 $MOD752 29 ****************** 30 31 :Timer value for 9600 baud @ 16 MHz. BaudVal EQU -139 FF75 32 ; (one bit cell time) 33 34 ;Data for RS-232 transmit routine. 0010 35 XmtDat DATA 10h ;RS-232 transmit bit count. DATA 12h 36 BitCnt 0012 ; Holds next value for updating the PWM. 37 PWMVa1 DATA 13h 0013 ;Holds last A/D conversion result. DATA 14h 0014 38 ADVal 39 0020 40 Flags DATA 20h ;Transmit-in-progress flag. Flags.0 0000 41 TxFlag ; Indicates A/D conversion complete. BIT Flags.1 0001 42 ADFlag 43 ;Port bit for RS-232 transmit. 0095 44 P1.5 45 *********************** 46 47 48 ; Interrupt Vectors 49 0000 50 ORG ;Reset vector. AJMP Reset 0000 0135 51 52 ORG 0BH ;Timer 0 interrupt. 000B 53 AJMP Timr0 ; (used as a baud rate generator) 000B 01C5 54 55 ;A/D conversion complete interrupt. ORG 56 002B AJMP ADInt 002B 0199 57 58 ``` | DEMO752C | | 87C752 A/D | and PWM Demonstra | 12/03/90 PAGE | |------------------------|----------|------------------|--------------------|---------------------------------------------| | 0033 | 59 | ORG | 33h | ;PWM interrupt. | | 0033 01A3 | 60 | AJMP | PWMInt | /IWM Intellupe. | | | 61 | | 1 11111110 | | | | 62 | | | | | | 63 | ;********* | ****** | ************** | | | 64 | | | | | 0035 758130 | 65 | Reset: MOV | SP,#30h | | | 0038 752000 | 66 | MOV | Flags,#0 | ;Clear RS-232 flags. | | 003B 758800 | 67 | MOV | TCON, #00h | ;Set up timer controls. | | 003E 75A882 | 68 | MOV | IE,#82h | ;Enable timer 0 interrupt. | | | 69 | | | | | 0041 90011B | 70 | MOV | DPTR, #Msg1 | ; Point to message string. | | 0044 310A | 71 | ACALL | Mess | ;Send message. | | | 72 | | | | | 0046 7900 | 73 | VOM | R1,#0 | ;Start with A/D channel 0. | | 048 E9 | 74 | Loop1: MOV | A,R1 | | | 049 118D | 75 | ACALL | ADConv | ;Start A/D conversion. | | 004B FA | 76 | VOM | R2,A | | | 040 000150 | 77 | | | | | 04C 900152 | 78 | VOM | DPTR,#Msg2 | ; Point to message string. | | 04F 310A | 79 | ACALL | Mess | ;Send message. | | 051 E9 | 80 | VOM | A,R1 | | | 052 11EC | 81 | ACALL | PrByte | ;Print channel #. | | 054 900161<br>057 310A | 82 | VOM | DPTR,#Msg3 | ;Point to message string. | | 057 310A | 83 | ACALL | Mess | ;Send message. | | 059 EA | 84 | | | | | 05A 11EC | 85 | MOV | A,R2 | | | 05C 09 | 86<br>87 | ACALL | PrByte | ;Print A/D value. | | 05D B905E8 | 88 | INC | R1 | ;Advance R1 value. | | 060 90014F | 89 | CJNE | R1,#5,Loop1 | | | 063 310A | 90 | VOM | DPTR, #CRLF | ;Point to message string. | | | 91 | ACALL | Mess | | | | 92 | : Now use A/D ch | annel 0 value to o | rombural the pro- | | | 93 | / NOW dae A/D CI | dimer o varue to o | control the PWM. | | 065 758FFF | 94 | MOV | PWMP,#0FFh | Cat Diny -1 - 5 | | 068 758E00 | 95 | MOV | PWCM, #0 | ;Set PWM slow frequency. | | 06B 751300 | 96 | MOV | PWMVal,#0 | ;Set initial PWM value. | | 06E 75FE01 | 97 | MOV | PWENA,#1 | ;Default starting value for the PWM. | | 071 75A8CA | 98 | MOV | IE,#0CAh | ;Start PWM | | | 99 | | , | ;Now enable the A/D and PWM interrupts. | | 7400 | 100 | Loop2: MOV | A,#0 | ·Pond A/D shares 1 0 | | 076 1186 | 101 | ACALL | ADStart | ;Read A/D channel 0. ;Start A/D conversion. | | 078 3001FD | 102 | JNB | ADFlag,\$ | | | 07B E514 | 103 | MOV | A, ADVal | ;Wait for A/D conversion complete. | | 07D 11EC | 104 | ACALL | PrByte | ;Get A/D result to print. ;Print PWM value. | | 07F 900165 | 105 | MOV | DPTR, #Msg4 | | | 082 310A | 106 | ACALL | Mess | ;Point to message string. | | 084 80EE | 107 | SJMP | Loop2 | | | | 108 | | | | | | 109 | | | | | | 110 | ; A/D Conversion | Routines. | | | | 111 | ; The followin | g shows two wavs t | o use the A/D. Both routines are used by | | | 112 | ; different po | rtions of the samp | le program. | | | 113 | - · | Damp | E54 MIII. | | | 114 | ; Method 1: Th | is version of the | routine starts the conversion and then | | | 115 | ; returns. The | mainline program | can detect when the conversion is | | | 116 | ; complete by | checking the A/D c | onversion complete flag (ADFlag) which is | | DEMO752C | | 87C7 | 752 A/D and | PWM Demon | stration | | 12/03/90 PAGE 3 | |------------------------|------------|----------|-------------|-------------|-----------|------------------------------------------|----------------------| | | | | | | | | | | | | | | | | outine. A/D data mus | t he read by the | | | 117 | | | | service i | Outline. A/D data mas | to be read by the | | | 118 | ; call: | ing routine | €. | | | | | 0006 0001 | 119 | ADCtomt. | CI D | ADFlag | | ;Clear A/D conversi | on complete flag. | | 0086 C201 | 120 | ADStart: | | A,#28h | | ;Add control bits t | | | 0088 4428<br>008A F5A0 | 121<br>122 | | MOV | ADCON, A | | ;Start conversion. | | | 008C 22 | 123 | | RET | 1100011,11 | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | 0000 22 | 124 | | TCD1 | | | | | | | 125 | | | | | | | | | 126 | ; Meth | od 2: This | is an alte | rnative v | version of the A/D ro | outine which | | | 127 | ; star | ts the con | version and | then wai | its for it to complet | e before | | | 128 | ; retu | rning. A/D | data is re | turned ir | n the ACC. | | | | 129 | | | | | | | | 008D 4428 | 130 | ADConv: | ORL | A,#28h | | ;Add control bits t | co channel #. | | 008F F5A0 | 131 | | MOV | ADCON, A | | ;Start conversion. | | | 0091 E5A0 | 132 | ADC1: | VOM | A, ADCON | | | | | 0093 30E4FB | 133 | | JNB | ACC.4,ADC1 | | ;Wait for conversion | on complete. | | 0096 E584 | 134 | | VOM | A, ADAT | | ;Read A/D. | | | 0098 22 | 135 | | RET | | | | | | | 136 | | | | | | | | | 137 | - (- : | | | | | | | | 138 | ; A/D in | terrupt se | rvice routi | ne. | | | | 0000 8504 | 139 | ADTet | MOV | A, ADAT | | ;Read A/D data. | | | 0099 E584<br>009B F514 | 140<br>141 | ADInt: | MOV | ADVal,A | | ;Save A/D data for | print routine. | | 009B F314<br>009D F4 | 142 | | CPL | A | | ;Complement the va | | | 009E F513 | 143 | | MOV | PWMVal,A | | ;Set new value for | | | 00A0 D201 | 144 | | SETB | ADFlag | | | w A/D data is ready. | | 00A2 32 | 145 | | RETI | | | | | | | 146 | | | | | | | | | 147 | | | | | | | | | 148 | ; PWM in | terrupt se | rvice rout: | ine allow | s updating the PWM s | ynchronously. | | | 149 | | | | | | | | 00A3 85138E | 150 | PWMInt: | VOM | PWCM, PWMV | al | ;Update PWM duty c | ycle. | | 00A6 32 | 151 | | RETI | | | | | | | 152 | | | | | | | | | 153 | 1.3 | 6.28 | | | | | | | 154 | ; Send a | a byte out | RS-232 and | wait for | completion before r | eturning. | | | 155 | | | D.GIV. | | g | 2 01111111 | | 00A7 11AD | 156 | XmtByte: | | RSXmt | | ;Send ACC to RS-23<br>;Wait for transmit | | | 00A9 2000FD | 157 | | JB<br>RET | TxFlag,\$ | | ; wait for transmit | Comprete. | | 00AC 22 | 158<br>159 | | KEI | | | | | | | 160 | | | | | | | | | 161 | Begin | RS-232 tra | ensmit. | | | | | | 162 | , Degin | 110 202 020 | | | | | | 00AD F510 | 163 | RSXmt: | MOV | XmtDat,A | | ;Save data to be t | ransmitted. | | 00AF 75120A | 164 | | MOV | BitCnt,#1 | 0 | ;Set bit count. | | | 00B2 758CFF | 165 | | MOV | TH,#High | | ;Set timer for bau | d rate. | | 00B5 758A75 | 166 | | VOM | TL, #Low B | | | | | 00B8 758DFF | 167 | | VOM | RTH,#High | BaudVal | ;Also set timer re | load value. | | 00BB 758B75 | 168 | | MOV | RTL,#Low | BaudVal | | | | 00BE D28C | 169 | | SETB | TR | | ;Start timer. | | | 00C0 C295 | 170 | | CLR | TxD | | ;Begin start bit. | | | 00C2 D200 | 171 | | SETB | TxFlag | | ;Set transmit-in-p | rogress flag. | | 00C4 22 | 172 | | RET | | | | | | | 173 | | | | | | | | | 174 | | | | | | | # Using the ADC and PWM of the 83C752/87C752 | DEMO752C | 87C752 A/ | D and PWM Demonstra | ation 12/03/90 PAGE 4 | |--------------------------------|-----------------|---------------------------------|------------------------------------------------| | | | | | | 175 | minor 0 1 inc | | | | 175<br>176 | ; Timer U time | eout: RS-232 receive | e bit or transmit bit. | | 00C5 C0E0 177 | TimeO. Ducu | 100 | | | | Timr0: PUSH | ACC | | | | PUSH | PSW | | | | JB | TxFlag,TxBit | ; Is this a transmit timer interrupt? | | 0000 -0 | T0Ex1: CLR | TR | ;Stop timer. | | | T0Ex2: POP | PSW | | | 00D0 D0E0 182 | POP | ACC | | | 00D2 32 183 | RETI | | | | 184 | | | | | 185 | | | | | 186 | ; RS-232 trans | mit bit routine. | | | 187 | | | | | 00D3 D51204 188 | TxBit: DJNZ | BitCnt, TxBusy | ;Decrement bit count, test for done. | | 00D6 C200 189 | CLR | TxFlag | ;End of stop bit, release timer. | | 00D8 80F2 190 | SJMP | T0Ex1 | ;Stop timer and exit. | | 191 | | | | | 00DA E512 192 | TxBusy: MOV | A,BitCnt | ;Get bit count. | | 00DC B40104 193 | CJNE | A,#1,TxNext | ;Is this a stop bit? | | 00DF D295 194 | SETB | TxD | ;Set stop bit. | | 00E1 80EB 195 | SJMP | T0Ex2 | Exit. | | 196 | | | | | 00E3 E510 197 | TxNext: MOV | A, XmtDat | ;Get data. | | 00E5 13 198 | RRC | A | ;Advance to next bit. | | 00E6 F510 199 | MOV | XmtDat, A | mavance to next bit. | | 00E8 9295 200 | MOV | TxD,C | ;Send data bit. | | 00EA 80E2 201 | SJMP | T0Ex2 | Exit. | | 202 | | | , BAIC. | | 203 | | | | | 204 | ; Print byte r | Outine: print ACC c | ontents as ASCII hexadecimal. | | 205 | , | outine. print Acc c | oncenes as ASCII nexadecimal. | | 00EC C0E0 206 | PrByte: PUSH | ACC | | | 00EE C4 207 | SWAP | A | | | 00EF 11FA 208 | ACALL | | | | 00F1 11A7 209 | ACALL | | | | 00F3 D0E0 210 | POP | ACC | | | 00F5 11FA 211 | ACALL | | <b>D</b> 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 00F7 11A7 212 | ACALL | | ;Print nibble in ACC as ASCII hex. | | 00F9 22 213 | RET | XmtByte | | | 214 | KEI | | | | 215 | | | | | 216 | · Hevadogimal + | TO ACCUTE TO | | | 217 | , menadecimal t | to ASCII conversion | routine. | | 00FA 540F 218 | HexAsc: ANL | | | | 00FC 30E308 219 | | A,#0FH | ;Convert a nibble to ASCII hex. | | 00FF 20E203 220 | JNB | ACC.3,NoAdj | | | | JB | ACC.2,Adj | | | | JNB | ACC.1,NoAdj | | | 0105 2407 222<br>0107 2430 223 | Adj: ADD | A,#07H | | | <del></del> | NoAdj: ADD | A,#30H | | | 0109 22 224 | RET | a di Santa di Barana.<br>Barana | | | 225 | | | | | 226 | 22 0 0 | | | | 227 | ; Message strin | ng transmit routine. | | | 228 | | | | | 010A COEO 229 | Mess: PUSH | ACC | | | 010C 7800 230 | VOM | R0,#0 | ;R0 is character pointer (string | | 010E E8 231 | Mesl: MOV | A,R0 | ; length is limited to 256 bytes). | | 010F 93 232 | MOVC | A, @A+DPTR | ;Get byte to send. | | | | | | **AN428** | DEMO752C | | | 37C752 A/D | and PWM Demon | stration | | | 12/03/90 | PAGE 5 | |-----------|--------|----------|------------|---------------|-----------|------------|-----------|--------------|--------| | 0110 B400 | 03 23 | 33 | CJNE | A,#0,Send | | ;End of s | tring is | indicated by | a 0. | | 0113 D0E0 | 23 | 34 | POP | ACC | | | | | | | 0115 22 | 23 | 35 | RET | | | | | | | | | 23 | 36 | | | | | | | | | 0116 11A7 | 23 | 37 Send: | ACALL | XmtByte | | ;Send a | haracter. | | | | 0118 08 | 2 | 38 | INC | R0 | | ;Next cha | racter. | | | | 0119 80F3 | 2 | 39 | SJMP | Mesl | | | | | | | | 24 | 40 | | | | | | | | | 011B 0D0A | . 24 | 41 Msgl: | DB | ODh, OAh, | | | | | | | 011D 5468 | 6973 2 | 42 | DB | 'This is a | demonstr | ation of t | he 87C752 | A/D and PWM. | | | 0121 2069 | 7320 | | | | | | | | | | 0125 6120 | 6465 | | | | | | | | | | 0129 6D6F | 6E73 | | | | | | | | | | 012D 7472 | 6174 | | | | | | | | | | 0131 696F | 6E20 | | | | | | | | | | 0135 6F66 | 2074 | | | | | | | | | | 0139 6865 | 2038 | | | | | | | | | | 013D 3743 | 3735 | | | | | | | | | | 0141 3220 | 412F | | | | | | | | | | 0145 4420 | 616E | | | | | | | | | | 0149 6420 | 5057 | | | | | | | | | | 014D 4D2E | 2 | | | | | | | | | | 014F 0D0A | .00 2 | 43 CRLF: | DB | 0Dh, 0Ah, | 0 | | | | | | | 2 | 44 | | | | | | | | | 0152 ODOA | 412F 2 | 45 Msg2: | DB | 0Dh, 0Ah, | 'A/D Char | nel ', 0 | | | | | 0156 4420 | 14368 | | | | | | | | | | 015A 616E | E6E65 | | | | | | | | | | 015E 6C20 | 000 | | | | | | | | | | | 2 | 46 | | | | | | | | | 0161 2031 | 2000 2 | 47 Msg3: | DB | ′ = ′, 0 | | | | | | | | 2 | 48 | | | | | | | | | 0165 2020 | 000 2 | 49 Msg4: | DB | ′ ′, 10 1 | | | | | | | | | 50 | | | | | | | | | | 2 | 51 | END | | | | | | | | | | | | | | | | | | ASSEMBLY COMPLETE, 0 ERRORS FOUND | DEMO752C | 87C752 A/D and I | PWM Demonstration | 12/03/90 PAGE 6 | |----------|------------------|-------------------|-----------------------| | ACC | . D ADDR 00E0F | H PREDEFINED | | | ADAT | . D ADDR 0084F | | | | ADC1 | . C ADDR 0091H | | | | ADCON | . D ADDR 00A0H | | | | ADCONV | . C ADDR 008DF | | | | ADFLAG | . B ADDR 0001H | | | | ADINT | . C ADDR 0099H | | | | ADJ | . C ADDR 0105H | | | | ADSTART | . C ADDR 0086H | | | | ADVAL | . D ADDR 0014H | | | | BAUDVAL | . NUMB FF75H | | | | BITCNT | . D ADDR 0012H | | and the second second | | CRLF | . C ADDR 014FH | | | | FLAGS | . D ADDR 0020H | | | | HEXASC | . C ADDR 00FAH | | | | IE | . D ADDR 00A8H | | | | LOOP1 | . C ADDR 0048H | | | | LOOP2 | . C ADDR 0074H | | | | MESL | . C ADDR 010EH | | | | MESS | . C ADDR 010AH | | | | MSG1 | . C ADDR 011BH | | | | MSG2 | . C ADDR 0152H | | | | MSG3 | . C ADDR 0161H | | | | MSG4 | . C ADDR 0165H | | | | NOADJ | . C ADDR 0107H | | | | P1 | . D ADDR 0090H | | | | PRBYTE | . C ADDR 00ECH | | | | PSW | . D ADDR 00D0H | | | | PWCM | . D ADDR 008EH | | | | PWENA | . D ADDR 00FEH | PREDEFINED | | | PWMINT | . C ADDR 00A3H | | | | PWMP | . D ADDR 008FH | PREDEFINED | | | PWMVAL | . D ADDR 0013H | | | | RESET | . C ADDR 0035H | | | | RSXMT | . C ADDR 00ADH | | | | RTH | . D ADDR 008DH | PREDEFINED | | | RTL | . D ADDR 008BH | PREDEFINED | | | SEND | . C ADDR 0116H | | | | SP | . D ADDR 0081H | PREDEFINED | | | T0EX1 | . C ADDR 00CCH | | | | T0EX2 | . C ADDR 00CEH | | | | TCON | . D ADDR 0088H | PREDEFINED | | | TH | . D ADDR 008CH | PREDEFINED | | | TIMRO | . C ADDR 00C5H | | | | TL | . D ADDR 008AH | PREDEFINED | | | TR | . B ADDR 008CH | PREDEFINED | | | TXBIT | . C ADDR 00D3H | | | | | . C ADDR 00DAH | | | | TXD | . B ADDR 0095H | | | | TXFLAG | . B ADDR 0000H | | | | TXNEXT | . C ADDR 00E3H | | | | | . C ADDR 00A7H | | | | XMTDAT | . D ADDR 0010H | | | Philips Semiconductors Application note # Airflow measurement using the 83/87C752 and "C" **AN429** #### INTRODUCTION This application note describes a low-cost airflow measurement device based on the Phillips 83/87c752 microcontroller. Airflow measurement—determining the volume of air transferred per unit time (cubic feet per minute, or cfm)—is intrinsic to a variety of industrial and scientific processes. Airflow computation depends on three simultaneous physical air measurements—velocity, pressure, and temperature. This design includes circuits and sensors allowing the 8XC752 to measure all three parameters. The design also includes seven-segment LED displays, discrete LEDs, and pushbutton switches to allow selective display of airflow, temperature, and pressure. Furthermore, airflow is continuously compared with a programmer-defined setpoint. Should the measured airflow exceed the setpoint, an output relay is energized. In actual application, this relay output could be used to signal the setpoint violation (via lamp or audio annunciator) or otherwise control the overall process (e.g., emergency process shutdown). Of course, the setpoint, comparison criteria (greater, less than, etc.) and violation response (relay on, relay off) are easily changed by program modification to meet actual application requirements. Referring to Figure 1, the overall operation of the airflow device is as follows. Normally the unit continuously displays the airflow (in cfm) on the seven-segment displays. The discrete CFM LED is also lit to confirm the parameter being displayed. Pressing the TEMP pushbutton switches the display to temperature (in degrees C) and lights the TEMP LED. As long as the pushbutton remains pressed, the temperature is displayed. When the pushbutton is released, the display reverts to the default pressure display. Similarly, pressing the PSI pushbutton displays the atmospheric pressure (in pounds per square inch) and lights the PSI LED. The pressure is displayed as long as the pushbutton is pressed, and the default airflow display resumes when the pushbutton is released. Finally, pressing the SET-POINT pushbutton displays the programmed airflow setpoint (in cfm) and lights the SET-POINT LED. Again, releasing the pushbutton causes the display to revert to the default airflow measurement. # CONTROL PROGRAMMING IN "C" While, thanks to advanced semiconductor processing, hardware price/performance continues to improve, software development technology has changed little over time. Thus, given ever-rising costs for qualified personnel, software "productivity" is arguably in decline. Indeed, for low-unit cost and/or low-volume applications, software development has emerged as the major portion of total design cost. Furthermore, beyond the initial programming cost, "hidden" costs also arise in the form of life-cycle code maintenance and revision and lost revenue/market share due to excessive time-to-market. Traditionally, control applications have been programmed in assembly language to overcome microcontroller resource and performance constraints. Now, thanks to more powerful microcontrollers and advanced compiler technology, it is feasible to program control applications using a High-Level Language (HLL). The primary benefit of using an HLL is obvious—one HLL program "statement" can perform the same function as many lines of assembly language. Furthermore, a well-written HLL program will typically be more "readable" than an assembly language equivalent, resulting in reduced maintenance and revision/upgrade costs. Of the many popular HLLs, the "C" language has emerged as the major contender for control applications. More than other languages, C gives the programmer direct access to, and control of, low-level hardware resources—a requirement for deterministic, real-time I/O applications. Furthermore, C is based on a "minimalist" philosophy in which the language performs only those functions explicitly requested by the programmer. This approach is well-suited for control applications, which are often characterized by strict cost and performance requirements. Figure 1. Airflow Meter Front Panel AN429 #### **8XC752 OVERVIEW** The 83C752/87C752 (ROM/EPROM-based) combine the performance advantages of the 8-bit 80C51 architecture with the low cost, power consumption, and size/pin count of a 4-bit microcontroller. Therefore, the 8XC752 is uniquely capable of bringing high processing speed and HLL programming to even the most cost-sensitive applications such as handheld (battery driven) instruments, automotive distributed processing, "smart" appliances, and sophisticated consumer electronics. Obviously, the 8XC752 can be used for cost-reduced versions of existing 8-bit applications. The device can also replace similarly priced 4-bit devices to achieve benefits of higher performance and, most importantly, easier s/w development including the use of HLL. Indeed, the component and system design costs associated with the 8XC752 are so low that it is a viable candidate for first-time computerization of formerly non-microcontroller-based designs. Figure 2 shows the block diagram of the 8XC752. Major features of the device include the following. # Full-Function, High-Speed (to 16MHz) 80C51 CPU Core The popular 80C51 architecture features 8and 16-bit processing and high-speed execution. Most instructions execute in a single machine cycle (the slowest instructions require only two cycles). Though a streamlined architecture, the CPU core, unlike 4-bit devices, includes all the basic capabilities (such as stack, multiply instruction, interrupts, etc.) required to support HLL compilation. The CPU core also includes a unique Boolean processor which is well-suited for the bit-level processing and I/O common to control applications. # Low-Power CMOS and Power-Saving Operation Modes Thanks to the advanced CMOS process, the 8XC752 features extremely low power consumption, which helps to extend battery life in handheld applications and otherwise reduce power supply and thermal dissipation costs and reliability concerns. Low ACTIVE mode (full-speed operation) power consumption—only 11mA typical at 12MHz—is further complemented by two program-initiated power-saving operation modes—IDLE and POWER-DOWN. In idle mode, CPU instruction processing stops while on-chip I/O and RAM remain powered. Power consumption drops to 1.5μA (typical, 12MHz) until processing is restarted by interrupt or reset. Power-down mode cuts power consumption further (to only 10μA typical at 12MHz) by stopping both instruction and I/O processing. Return to full-speed operation from power-down mode is via Note that power consumption can be further cut by reducing the clock frequency as much as application performance requirements allow, as shown in Figure 3. Another virtue of the CMOS process is superior tolerance to variations in $V_{CC}$ , a requirement inherent in the targeted applications. The EPROM-based device (87C752) operates over a $V_{CC}$ range of 4.5V to 5.5V, while the ROM-based device (83C752) will operate from 4V to 6V. # On-Chip ROM (83C752), EPROM (87C752), and RAM The 8XC752 integrates 2048 bytes of program ROM/EPROM and 64 bytes of data RAM. This relatively small amount of memory reflects the fact that the targeted applications, though they may require high-speed processing, are typically characterized by simple algorithms and data structures. High code efficiency of the architecture means even this small amount of memory can effectively support the use of C. If necessary, the judicious use of assembly language can help bypass code size (and performance) constraints. ### Five-Channel 8-Bit A/D Converter Most control applications are characterized by the need to monitor "real-world" (i.e., analog) parameters. To this end, the 8XC752 includes a medium-speed (40 clock cycle conversion) 8-bit analog-to-digital (A/D) converter. Five separate input lines are provided along with multiplexer logic to select an input for conversion. The A/D converters speed, resolution, and accuracy are more than adequate to measure temperature, pressure, and other common environmental parameters. Figure 2. Block Diagram of the 8XC752 ### **Timer/Counters** Control applications, due to their "real-time" nature, invariably call for a variety of timing and counting capabilities. The 8XC752 meets the need by integrating three separate functions—a 16-bit auto-reload counter/timer, an 8-bit pulse width modulator (PWM) output/timer, and a fixed-rate timer for timebase generation. Together, these timing/counting resources can serve a range of tasks, including waveform generation, external event counting, elapsed time calculation, periodic interrupt generation, and watchdog timer. ### I<sup>2</sup>C Bus The Inter-Integrated Circuit (I<sup>2</sup>C) bus is a patented serial peripheral interface. The virtue of I<sup>2</sup>C is the ability to expand system functionality with acceptable performance and minimum cost. Notably, the pin and interconnect count is radically reduced compared to expansion via a typical microprocessor bus—I<sup>2</sup>C requires only two lines, while a parallel bus often consumes 20-30 lines and may call for extra glue logic (decoder, address latch, etc.). The 8XC752 I<sup>2</sup>C port allows easy connection to a wide variety of compatible peripherals such as LCD drivers, A/D and D/A converters, consumer/telecom and special-purpose memory (e.g., EEPROM). I<sup>2</sup>C can also be used to build distributed processing systems connecting multiple I<sup>2</sup>C-compatible microcontrollers. Philips Semiconductors Application note ### Airflow measurement using the 83/87C752 and "C" AN429 Figure 3. I<sub>CC</sub> vs. FREQ ### **8XC752 PIN FUNCTIONS** Since the 8XC752 is packaged in a cost/space-saving 28-pin package DIP or PLCC), a flexible mapping of I/O functions to pins is required to ensure the widest possible application coverage. Of the 28 pins, seven pins are allocated to basic functions, including digital power ( $V_{CC}$ , $V_{SS}$ ), analog reference ( $AV_{CC}$ , $AV_{SS}$ ), clock oscillator (X1, X2), and reset (RST). Thus, 21 pins, organized into three ports (5-bit port 0, 8-bit ports 1 and 3), are available for user I/O. Figure 4 shows the alternative uses for these 21 lines. As shown, the mapping is quite versatile, which maximizes the access to on-chip I/O functions and helps ensure full pin utilization. Figure 4. 8XC752 I/O Port Description Application note ### Airflow measurement using the 83/87C752 and "C" AN429 # AIRFLOW METER CIRCUIT DESCRIPTION Figure 5 is the schematic diagram of the airflow meter circuit. As shown, the 8XC752 is connected to the following function blocks. # Discrete and Seven-Segment LED Display The seven-segment LEDs display the parameter of interest (airflow, temperature, pressure, or setpoint). A discrete LED associated with each parameter is lit when that parameter is being displayed. The seven-segment LEDs are identified as X0.1, X1, and X10, reflecting their decimal position (tenths, ones, and tens, respectively). Each display has eight data inputs (the seven segments and a decimal point) and common terminals which allow the display to be enabled or blanked. The eight data inputs, and the four discrete LEDs, are driven from port 3 of the 8XC752 via high-current driver U2 and current limiting resistors RP1. Since all the segmented and discrete LEDs share common data lines, data display must be time multiplexed. Transistors Q1-Q4 connect to separate output lines of port 0, allowing a particular seven-segment LED or the discrete LEDs (as a group) to be individually enabled for display. This type of LED multiplexing is quite common since, at a fast enough refresh rate, the switching between displays is not perceptible by the operator. The major benefit is the reduction of I/O lines required (without multiplexing, 28, rather than 8, data lines would be required). ### **Pushbutton Switch Inputs** Three pushbuttons select the parameter to be displayed—temperature, pressure, or setpoint (when no button is pressed, airflow is displayed). The four states (SW1, SW2, SW3, or no button pressed) are effectively encoded onto two port 1 input lines (taking advantage of the capability to use port 1 lines configured as A/D for TTL input) as follows: | | P1.3 | P1.4 | |------------------------|------|------| | No button pressed | HIGH | HIGH | | SW1 (TEMP) pressed | LOW | HIGH | | SW2 (PSI) pressed | HIGH | LOW | | SW3 (SETPOINT) pressed | LOW | LOW | The only impact of this encoding scheme is that SW3 has a higher priority than the other pushbuttons—a factor of no concern in this simple application. Similarly, latching, debouncing, rollover, or other conditioning of the pushbutton inputs is not required. ### **Setpoint Control** This is simply a variable resistor voltage divider which serves to establish an analog voltage corresponding to an airflow threshold at which action is taken. It connects to a port 1 A/D input. ### **Relay Output** When an airflow setpoint violation is detected, DPDT relay K1 is energized via P1.6, which is configured as a TTL output, buffered by transistor Q5. #### Flowmeter Input Measurement of the air velocity is via an air turbine tachometer connected, via optoisolator U7, to P1.5, which is configured as a TTL input. The tachometer input is assumed to be a negative-going pulse train with less than 10% duty cycle. #### **Air Pressure Sensor** To determine airflow, the air velocity must be factored by ambient pressure—for a given velocity (and temperature), lower/higher atmospheric pressure will correspond with lower/higher airflow. The pressure sensor, U3, outputs a voltage differential corresponding to the pressure. Amplifier U4 conditions the pressure sensor output to the range of AV<sub>SS</sub> to AV<sub>CC</sub> (the analog references for the 8XC752 A/D converter). The conditioned pressure sensor output is presented to A/D input P1.0. To calibrate the pressure sensor, press the PSI pushbutton and adjust the gain pot (R1) until the display matches the local atmospheric pressure in pounds per square inch (14.7 at sea level). ### **Air Temperature Sensor** Similar to pressure, ambient temperature also affects the airflow calculation. For a given air velocity (and pressure), higher/lower temperature will correspond with lower/higher airflow. Temperature sensor U5 outputs an absolute voltage corresponding to temperature. Amplifier U6 conditions the temperature sensor output to the range AV<sub>SS</sub> to AV<sub>CC</sub> for connection to AV D input P1.1. To calibrate the temperature sensor, adjust the gain pot (R5) so that the display (while pressing the TEMP pushbutton) matches the measured output of U5 (LM35). Figure 6 summarizes the usage of the 8XC752 I/O lines in this application. Figure 5. Schematic Diagram of the Airflow Meter Circuit AN429 ### Figure 6. Airflow Meter I/O Port Usage # SOFTWARE DEVELOPMENT PROCEDURE The airflow meter application software is almost entirely written in C using a development package from Franklin Software. The Franklin Software C compiler is a cross-compiler that runs on the IBM PC (and compatibles) while generating code suitable for execution by any 80C51-based product, including the 8XC752. For more information, contact: Franklin Software 888 Saratoga Ave., #2 San Jose, CA 95129 The process of developing a C program using the Franklin package (the process is similar for other third-party cross-compilers) is as - The program is entered/edited on the PC using the programmer's preferred text editor. - 2. The program is compiled on the PC with the Franklin C compiler. - Should compile errors (also known as syntax errors) occur, they are corrected by returning to step 1 until an error-free compile is achieved. - 4. Before testing the compiled program, it needs to be combined, using the Franklin-supplied linker, with any required assembly language routines. Besides routines explicitly written by the programmer, every Franklin C program requires an assembly language startup routine (supplied by Franklin and, if necessary, edited by the programmer) which performs basic reset initialization and configuration operations before transferring control to the C program. - The compiled object code is tested for correct operation. This can either be accomplished by using an 80C51-family simulator running on the PC or by downloading the object code to an in-circuit emulator. The simulator - approach has the virtues of low cost and consolidation of all work on the PC at the cost of non-real-time operation/debug constraints (the simulator may execute 100-1000 times slower than the microcontroller). The in-circuit emulator provides real-time operation and the additional benefit of assisting hardware design debug at somewhat higher cost. - Should program execution prove faulty (known as semantic errors), return to step 1 until error-free operation is achieved. - 7. The error-free (syntax and semantic) and linked object code, in the form of a .HEX file, is transferred to an EPROM programmer. Fitted with a suitable adaptor, the EPROM programmer can "burn" the object file into the targeted EPROM-based 80C51-family device. For ROM-based devices, the object file is transferred to the factory for custom masking. AN429 ### PROGRAM DESCRIPTION Figure 7 is a flowchart of the program; following the flowchart is the program listing. The flowchart shows the basic processing and flow, while the listing documents the details of the program's implementation. The program consists of four interrupt-driven (i.e., foreground) routines and a main program (i.e., background). The background program is entered at reset and executes forever, interrupted periodically by the foreground interrupts. Communication between the background program and the foreground handlers is via shared variables. The four interrupt routines are as follows. multiplex () (INT3) Free-running Timer I generates an interrupt at approximately 1000Hz and is used to multiplex the seven-segment and discrete LED display data. In a round-robin manner, at each interrupt, the program turns off the previously enabled display and writes data to, and enables, the next display. Finally, the interrupt routine sets a pointer to the next display—at the next interrupt, that display will be refreshed. Thus, each display (tens, ones, tenths, discrete LEDs) will be refreshed every fourth interrupt, which is more than fast enough for a flicker-free display. • read\_switch () (INT6) The PWM prescaler is configured to generate a periodic interrupt (INT6) at about 97Hz. The program counts these interrupts, and every 32nd interrupt sets an "update" variable. The main program will change the display data when it detects that "update" is set and clear "update" to prepare for the next display cycle. Thus, display change frequency is about 33Hz (i.e., 33ms), which eliminates display glitches associated with pushbutton switch bounce. • calc\_cfm () (INT0) The air velocity turbine tachometer drives the 8XC752 INT0 interrupt pin. At each interrupt, the program reads Timer 0, which keeps track of the elapsed time (the low 16 bits of a 24-bit count in microseconds) between INT0 interrupts. The high-order 8-bit elapsed time count is cleared for possible updating by the following routine. overflow () (INT1) When Timer 0 overflows (generating an interrupt), the program increments the high-order 8 bits of a 24-bit variable, counting the microseconds between tachometer interrupts (handled by the previous routine). If this 8-bit value becomes too large (i.e., tachometer interrupts stop), a NOFLOW variable is set, which will cause the main program to display an EEE out-of-range indicator on the seven-segment LEDs. With the interrupt handlers executing the low-level timing and I/O, the main program, which is entered on reset and executes forever, consists of only three major steps. The temperature/pressure compensated airflow is calculated. First, the "base" cfm rate, as tracked by the calc\_cfm () tachometer interrupt is adjusted by removing the execution time of the calc\_cfm () handler itself. Next, the temperature is determined (A/D channel 1), and airflow is compensated. Similarly, the air pressure is determined (A/D channel 0) and airflow compensated again. Now that the true airflow is calculated, it is compared with the setpoint (adjusted with the variable resistor), which is determined by reading A/D channel 2. If the airflow is greater than the setpoint, the relay is closed. Otherwise, the relay is opened. Finally, the UPDATE flag (set by the 33Hz read\_switch () interrupt) is checked. If it is time to update, the data to be displayed is determined based on the pushbutton status and the state of the NOFLOW flag. The updated display data is initialized for later display on the LEDs by the multiplex () display refresh interrupt handler. Figure 7. Program Flowchart Figure 7. Program Flowchart (Continued) Figure 7. Program Flowchart (Continued) Figure 7. Program Flowchart (Continued) ### AN429 ``` this program measures the air flow through a rotary flowmeter and displays the calculated cfm. the output of the flowmeter tachometer is a small duty cycle pulse train with period which is proportional to the flow. the flow is compensated for changes in pressure and temperature to maintain calibration. if the flow exceeds an adjustable setpoint it energizes a 2 form c relay for user application. * / */ these pragmas specify compiler command line options /* generate code #pragma CODE /* and symbols #pragma SYMBOLS /* 60 lines per page #pragma PL (60) /* 120 cols per page #pragma PW (120) #pragma OT (3) /* single-chip mode #pragma ROM (SMALL) include the 8XC752-specific definitions and the standard i/o library. <reg752.h> #include <stdio.h> #include */ define symbolic names for program constants /* 0 degrees centigrade in 1/10 kelvin #define ZERO K 1/10 cfm in microseconds 444444T. #define ONE_TENTH_CFM /* 25 degrees centigrade in 1/10 kelvin 2980 #define STD TEMP 147 /* one atmosphere in 1/10 psi #define STD_ATM maximum period from meter 0x400000 0 \times 40 #define LOWEST_CFM commands to start appropriate #define 0x28 START_ADC0 0x29 a/d channel conversion cycle #define START_ADC1 #define START_ADC2 0x2a /* 0x2b START_ADC3 #define 0x2c #define START_ADC4 a/d converter status flags 0x10 #define ADCI 0x08 ADCS #define 0 \times 10 #define FREERUN_I /* P3 position for display segment 'a' #define SEG_A 0 \times 01 P3 position for 'cfm' led 0x01 #define CFM /* P3 position for display segment 'b' #define SEG_B 0 \times 02 /* P3 position for 'degrees' led #define DEGREES 0 \times 02 /* P3 position for display segment 'c' 0x04 #define SEG_C /* P3 position for 'psi' led 0 \times 04 #define PSI /* P3 position for display segment 'd' 80x0 #define SEG_D /* P3 position for 'setpoint' led 0x08 #define SETPOINT /* P3 position for display segment 'e' #define 0x10 SEG_E /* P3 position for display segment 'f' 0x20 #define SEG F P3 position for display segment 'g' 0x40 #define SEG_G /* P3 position for display decimal pt. 0x80 #define SEG_DP byte data type is unsigned 8-bit /* typedef unsigned char byte; word data type is unsigned 16-bit typedef unsigned int word; 1_word data type is unsigned 32-bit typedef unsigned long 1_word; /* define logical true / false #define TRUE 1 values for bit variables #define FALSE 0 ``` 459 ``` define look-up table of possible seven segment display characters. the table consists of 11 elements corresponding to the 10 digits ('0'-'9') and error symbol ('E') that can be displayed. Each element is defined by ANDing (|) the bit mask for each segment (SEG_A - SEG_G) comprising the character. the table contents need to be inverted before use to be compatible with U2 (udn2585a). for example, '~segments[3]' specifies the segment mask to display '3'. */ code byte segments [ ] = SEG_A SEG_B SEG_C SEG_D SEG_E SEG_F /* 0 */ SEG_B SEG_C /* 1 */ SEG_A SEG_B SEG_D SEG E /* 2 */ SEG_A SEG_B SEG_C SEG_D /* 3 */ SEG G SEG B SEG_C SEG F SEG_G SEG_A SEG_C SEG D SEG_F /* 5 */ SEG_G SEG_A SEG_C SEG_D SEG E SEG F SEG_G SEG A SEG_B SEG_C SEG_A SEG B SEG_C SEG_D /* 8 */ SEG_E SEG F SEG_G SEG_A SEG_B SEG C SEG_D SEG F /* 9 */ SEG G SEG_A SEG D SEG E SEG F SEG_G } ; define the '752 special function bits which control i/o lines. note that i/o line (and constant) names are capitalized RELAY = 0x96; active hi to turn on setpoint relay shit. STROBE_0 0x80; active hi to enable display status led's sbit STROBE_1 = 0x81; active hi to enable display cr15 (tenths) sbit STROBE 2 0x82; active hi to enable display cr14 (ones) shit NO FLOW 0x83: flag set when no flow detected sbit STROBE 3 = 0x84; active hi to enable display cr13 (tens) sbit SEL_0 0x93; active low pushbutton inputs used to sbit SEL_1 /* 0 \times 94: select the display mode sbit INTR = 0x95; sbit UPDATE 0x97; flag set when time to update display define memory variables. note memory variable names are lower case data cfm; gas flow in tenths of a cfm data word setpoint; relay setpoint in tenths of a cfm data word degree_c temperature in tenths centigrade data 1_word corr; intermediate calculation value data word psi; pressure in tenths of a psi data byte display0; variables to hold values for the data byte display1; displays during refresh. data bvte display2; display0=status LEDs, display1=CR15, data byte display3; /* display2=CR14, display3=CR13 data byte disp_pntr; pointer to next display to enable data byte refresh; /* counter determines display updates data byte high; /* bits 16 - 23 of flow period data byte middle; bits 8 - 15 of flow period bits 0 - 7 of flow period /* data byte low; /* data ticks; incremented by timer overflow the program consists of four interrupt handlers (multiplex, read_switch, overflow, calc_cfm) and a main program. multiplex - refresh the seven-segment and discrete status LEDs read_switch - signal periodic pushbutton sampling and display update overflow - accumulate high order bits of time between tach pulses calc_cfm - accumulate low order bits of time between tach pulses main - calc airflow, control relay, sample pushbuttons, update display * / multiplex - use the free-running I timer to multiplex the seven-segment and discrete leds at approx. 1000 hz. ``` AN429 \* / ``` void multiplex () interrupt 3 switch(disp_pntr) case 0x00: /* turn off display cr13 */ STROBE_3 = FALSE; /* turn off all segments */ P3 = 0xff; /* load segments for led's */ P3 = display0; /* turn on status led's */ STROBE_0 = TRUE; /* increment ptr to display disp_pntr = 1; break; case 0x01: STROBE_0 = FALSE; /* turn off status led's /* turn off all segments P3 = 0xff; /* load segments for tenths P3 = display1; /* turn on display cr15 STROBE_1 = TRUE; /* increment ptr to display disp_pntr = 2; break; case 0x02: /* turn off display cr15 */ STROBE_1 = FALSE; /* turn off all segments */ P3 = 0xff; /* load segments for units */ P3 = display2; STROBE_2 = TRUE; /* turn on display cr14 /* increment ptr to display disp_pntr = 3; break: case 0x03: /* turn off display cr14 */ STROBE_2 = FALSE; /* turn off all segments */ P3 = 0xff; /* load segments for tens */ P3 = display3; /* turn on display cr13 */ STROBE_3 = TRUE; /* increment ptr to display disp_pntr = 0; } /* read_switch - use the free running pwm prescaler to generate interrupts at 92 hz. every 32nd interrupt set the UPDATE flag which causes main () to sample the pushbuttons and update the led displays. void read_switch () interrupt 6 if (refresh++ == 32) UPDATE = TRUE; { refresh = 0; } /* overflow - whenever time0 overflows (from 0xffff to 0x0000) increment the variable 'ticks' which accumulates the highest order (16 - 23) bits of the gas flow period in microseconds. if the variable 'ticks' is greater than the period corresponding to a flow of < 0.1 \ \text{cfm} then set the NO_FLOW flag which causes main () to display '00.0' void overflow () interrupt 1 if (++ticks > LOWEST_CFM) { cfm = 0; ticks = 0; NO_FLOW = TRUE; ``` } ``` calc_cfm - an external interrupt (int0) generated by a tach pulse from the flowmeter transfers the current value of timer0 into variables 'low' and 'middle', and then resets the timers. the 'ticks' variable described above is also copied to variable 'high', and then reset to zero. the NO_FLOW flag is cleared to enable display by main () of the calculated cfm. */ void calc_cfm () interrupt 0 low = TLO; TL0 = 0; middle = THO; THO = 0; high = ticks; ticks = 0; NO_FLOW = FALSE; } after initializing pins and variables, enter a continuous loop to... - calculate the airflow based on the tach, temp and pressure inputs. - compare the airflow to the setpoint input, and control the relay. - if the UPDATE flag is set (by the read_switch interrupt handler), sample the pushbuttons and update the display data. */ void main () RELAY = 0; /* initialize output pins */ INTR = 1; UPDATE = 1; STROBE_0 = 0; STROBE_1 = 0; STROBE_2 = 0; STROBE_3 = 0; NO_FLOW = 0; I2CFG = FREERUN_I; /* enable I timer to run, no i2c = 0; RTT. /* timer 0 period 0x10000 u_seconds RTH = 0; PWMP = 255; /* pwm timer interrupt at 923 hz TR = 1; /* enable timer 0 IT0 = 1; /* INTO is edge active ticks /* initialize variables = 0; cfm = 0; low = 0; middle = 0; high = 0; degree_c = 250; /* 25.0 tenths degrees c psi = 147; /* 14.7 tenths psi corr = 0; refresh = 0; disp_pntr = 0; ΙE = 0xab; /* enable interrupts main execution loop, executes forever. */ while(1) ``` ``` */ calculate base cfm rate - first create long word representing flow rate period in microseconds. then subtract the time overhead in servicing the routine 'calc_cfm'. then divide the period into the period for 1/10 cfm, to get flow rate in 1/10 cfm resolution. */ corr = high * 0x10000L; corr += (middle * 0x100L); corr += low; corr -= CORRECTION; corr = ONE_TENTH_CFM / corr; read temperature - measure output from the LM35 sensor, scaled by the AMP-02. the scaling results in a range of 0 to 51.0 degrees centigrade, in 0.2 degree steps. ADCON = START_ADC1; while (ADCON & ADCS) ; degree_c = ADAT; degree_c *= 2; compensate cfm rate for temperature - convert temperature into degrees kelvin, then divide it into the measured flow rate multiplied by the calibration temperature of the flow- meter in degrees kelvin. (nominal 25 degrees centigrade) corr *= STD_TEMP; corr /= (ZERO_K + degree_c); read pressure - measure output of the KP100A pressure trans- ducer, scaled by the AMP_02. the scaling results in a range of 0 to 25.5 psi, in 1/10 psi steps. ADCON = START_ADC0; while (ADCON & ADCS) ; psi = ADAT; */ compensate cfm rate for pressure - multiply measured pres- sure and the calculated flow rate, and then divide it by the standard atmospheric pressure at sea-level. (nominal 14.7 psi) corr *= psi; corr /= STD_ATM; cfm = corr; */ read setpoint pot to obtain setpoint in the range of 0-25.5 cfm in 1/10 cfm steps. ADCON = START_ADC2; while (ADCON & ADCS) ; setpoint = ADAT; ``` ``` test if cfm rate greater or equal to the setpoint, and if so then energize relay if (setpoint > cfm) RELAY = 0; RELAY = 1; */ test if UPDATE flag has been set, and if so reset flag. if (UPDATE) UPDATE = 0; then test is the NO_FLOW flag has been set. if so then display '00.0' cfm if (NO_FLOW) display0 = ~CFM; display1 = ~segments[0]; display2 = ~(segments[0] SEG_DP); display3 = ~segments[0]; if the NO_FLOW flag was not set then read the display select pushbuttons, and display the appropriate data. else if (SEL_0) if (SEL_1) */ if no pushbutton is depressed then the default display is the flow rate in cfm. if the flowrate is greater than or equal to 30 cfm then display the overrange message 'EEE', otherwise display the flow in 'XX.X' format. */ if (cfm <= 300) display0 = ~CFM; display1 = ~segments[cfm % 10]; cfm /= 10; display2 = !(segments[cfm % 10]); cfm /= 10; display3 = ~segments [cfm % 10]; else display0 = ~CFM; display1 = ~segments[10]; display2 = ~segments[10]; display3 = ~segments[10]; } ``` AN429 ``` if the temp pushbutton (SW1) is pressed then display the air temperature. else display0 = ~DEGREES; display1 = ~segments[degree_c % 10]; degree_c /= 10; display2 = ~(segments[degree_c % 10] | SEG_DP); degree_c /= 10 display3 = ~segments[degree_c % 10]; else { if the psi pushbutton (SW2) is pressed then display the air pressure. if(SEL_1) display0 = ~PSI; display1 = ~segments[psi % 10]; psi /= 10; display2 = ~(segments[psi % 10] | SEG_DP) ; psi /= 10; display3 = ~segments[psi % 10] ; if the setpoint pushbutton (SW3) is pressed then display the setpoint. */ else display0 = ~SETPOINT; display1 = ~segments[setpoint % 10] ; display2 = ~(segments[setpoint % 10] | SEG_DP; setpoint /= 10; display3 = ~segments[setpoint % 10] ; } } ``` 465 Philips Semiconductors Application note # "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller **AN436** #### INTRODUCTION With conventional microprocessor based systems, the market was primarily concerned with performance, cost and features. With the advent of hand-held and portable computers, the prominent market requirements focus on size, weight and battery life. Given a mature 386SX/AT architecture that provides more than adequate performance for average notebook application usage, the design challenges for these machines revolve around developing low power systems that maximize battery usage. The features of a notebook PC are usually characterized as weight and battery life. The heaviest component of a PC is usually the battery and the choice of battery is dictated by the power required. Thus the performance of the power management scheme has a direct bearing on both these parameters. The battery life targets for notebook machines is around 5 hours (the air commute time from coast to coast USA). #### **OVERVIEW** Most of the power consumed by a fully powered PC is wasted. The hard disk spins constantly even though data transfers from the disk are very sporadic. PCs may sit unattended for periods where the user is distracted by a telephone call, for instance. There are two principle challenges in designing a power management system: the ability to power down various devices without affecting other devices on the same bus, and ensuring full compatibility with existing operating systems and applications. The largest user of power in a PC is the display sub-system (3–5 Watts) followed by the peripherals such as the hard disk (2–4 Watts), the main system memory (0.5–1.5 Watts), and the core logic (1 Watt). # INTEGRATED POWER MANAGEMENT The conventional PC architecture needs to be extended to support power management. Hardware needs to be added to provide power-down capabilities and software needs to be added to support the hardware and provide DOS compatibility. The software support is usually realized in the BIOS. The hardware support can be implemented with external circuitry. This external circuitry manages the power resources to individual sub-sections of the PC system as these resources dictate. The external circuitry monitors battery power, system activities and timed events. Conventionally, the external circuitry is comprised of a digital power management ASIC and associated components. The use of this part increases the chip count of the PC system. The power management system has to determine how the system resources are being used. The resource usage of a PC can be determined by monitoring events or activities. User activity is usually determined by monitoring the keyboard controller for keystroke events. Keystroke events can be indicated by interrupts to the PC core logic or IO reads to the keyboard controller location. The power management ASIC solutions on the market today, such as the VADEM/INTEL 82C347, VLSI VL82C312 and INTEL 80C386SL all require external analog support circuitry to completely implement the power management functions. For example, low battery detect is implemented by the use of external comparator chains and complex. close tolerance level detect circuitry. The cost of this external circuitry is usually a significant proportion of the overall cost of the power management solution. The 83/87C752 employs an internal analog-to-digital converter (ADC). The ADC can be used to implement the battery level detection function at no extra cost and with no extra support circuitry. The 83/87C752 is a member of the Philips 8051 family of high performance 8-bit microcontrollers. These processors have been optimized for sequential real time control applications. The 83/87C752 contains most of the features of the 80C51 and has the following features: - 2k bytes ROM - 64 bytes RAM - Single level interrupt structure - 16 bit programmable counter/timer - Two 8-bit and one 5-bit bi-directional IO norts - I2C serial interface - PWM with interrupt and overflow capability - 5 channels of 8-bit A/D - 28-pin DIP and PLCC. #### **FLEXIBILITY** ASIC solutions to power management offer rigid schemes which work adequately with a few notebook architectures, but rarely offer exactly what the designer requires. With the current competitive arena for laptop development, time-to-market and value added features have a significant impact on the sales success of a particular product. The 83/87C752 offers flexibility at a low price. the power management design requirements can be coded and configured in the controller software and One Time Programmable (OTP) devices can offer a quick low-cost implementation of the coded scheme. With these integrated functions that the 83/87C752 offers, and its ability to provide a complete solution to power resource control, this device is emerging to be the industry standard for power management. #### **TOPOLOGY** Figure 1 shows a block diagram of a typical system implementation. It employs the integrated power management scheme using the Philips microcontroller to handle the keyboard and power management functions. The CPU and coprocessor reside on the local bus with the system memory. A local bus controller monitors CPU bus cycles to see if they are memory or ISA cycles. It also integrates the interrupt and DMA functions. The ISA bus controller processes non-system memory bus cycles. A frequency generator is used to provide the system clocks and clock multiplexing. The peripheral controller integrates the communications and mass storage sub-system. The VGA sub-system shares the ISA bus with the peripheral controller. The VGA controller has associated VGA memory. Figure 2 shows the microcontroller with the external support devices. The frequency generator provides the system clocks. It must have the ability to change the frequency of the clocks without violating the minimum high or low times for the core logic. The Philips microcontroller can control the speed of the system clocks via frequency select pins on the frequency generator. Frequency generators such as the Avasem AV9127 can change the processor clock speed gradually and continuously without violating the minimum high or low times. The integrated controller monitors system activity via its digital input ports. It uses internal timers to time the intervals between activity. The power to the VGA and peripheral sub-systems is controlled by the digital output port pins via MOSFETs. Battery level and V<sub>CC</sub> is monitored by the onboard A/D converter. "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller **AN436** Figure 1. Integrated Power Management Scheme Figure 2. External Support Devices #### **OPERATION** The power management system operates like a state machine. Transitions from state to state are controlled by expiring timers which are retriggered by external events. On entering a state, external power is switched or clocks are modified. A typical power management system would employ six states: Full Power, Doze, Shutdown, Sleep, Suspend, and Off. The state diagram of Figure 3 shows the power management states and their interrelationships. #### **Full Power** Entry to this state is controlled by a transition of the ON/OFF switch. In this state all the power control outputs are asserted, and the clock generator is selected for the highest speed. The system runs at full speed and power. #### Doze This state is entered from the FULL POWER state. Entry into this state is controlled by an expired timer (typically 30 secs). The timer expired as a result of not being reloaded by a transition on an activity monitor input pin. In this state the frequency generator is instructed to reduce the clock speed to about half that of the previous state. #### Shutdown This state is also entered from the FULL POWER state and operates in parallel with the DOZE state. Entry into this state is controlled by an expired timer (typically 30 secs). The timer expired as a result of not being reloaded by a transition on an activity monitor pin. In this state the power to a particular peripheral or group of peripherals is removed via an external FET. #### Shutdown-Doze This is an intermediate state which implements the features of both the SHUTDOWN and DOZE states. Entry into this state from the DOZE state is controlled by an expired timer (typically 30 secs). The timer expired as a result of not being reloaded by a transition on an activity monitor pin. Entry into this state from the SHUTDOWN state is controlled by an expired timer also. The timer expired as a result of not being reloaded by a transition on an activity monitor input pin. In this state the power to a particular peripheral or group of peripherals is removed via an external FET and the frequency generator is instructed to reduce the clock speed to about half that of the FULL POWER state. #### Sleep This state is entered from either the DOZE state or SHUTDOWN state. Entry into this state is controlled by an expired timer (typically 30 secs). The length of this timer is usually longer than that employed in the DOZE or SHUTDOWN states. The timer expired as a result of not being reloaded by a transition on an activity monitor pin. The activity monitor may look for keystrokes or video activity as described below. In this state power is removed from the backlight and LCD modulation voltage regulator via external FETs. #### Suspend This state is entered from any of the above states. Entry into this state is controlled by a transition on an external suspend switch or a command from the BIOS. During this state, the microcontroller takes over the task of refreshing the system memory and removes the power from the rest of the system via external FETs. #### Off This state is entered from any of the above states. Entry into this state is controlled by a transition on an external switch or a command from the BIOS. Figure 3. Multi-State Power Management Scheme # "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller AN436 # POWER MANAGEMENT ELEMENTS Figure 4 shows the internal power management elements of the Philips controller. The Activity monitors contain combinatorial algorithms to monitor or poll an activity or combination of activities. The activity monitors reload programmable timers which toggle clock control and power control output pins. Each functional block is discussed in more detail below. #### **Power Outputs** The power outputs are logic level signals that control MOSFETs via level shifting circuitry. The MOSFETs switch power to the various blocks under power management control and are chosen to have a low R<sub>ds</sub> on which reduces the voltage drop across the DRAIN-SOURCE channel. The level shifting circuitry and MOSFET orientation is shown in Figure 5. C1 and R1 control the switchon edge and should be chosen to make the edge sufficiently slow to minimize the inrush current. This is necessary where the notebook computer employs solid chip tantalum capacitors which fail short-circuit on switchon current transients. R1 pulls the gate to the NiCAD supply rail. The NiCAD battery voltage is usually greater than +12 Volts. We can exploit this relatively high voltage to turn the MOSFETs hard on and further reduce the R<sub>ds</sub> on. The NPN transistor is operated as a cascode and gives no net inversion between the logic level and the state of the MOSFET. This is necessary to handle the default powerup mode of the port pins. For a lower performance and cost reduced system, a logic level FET can be used such as a MTM25N06L and driven directly from the microcontroller port. These logic level FETs usually have R<sub>ds</sub> on specifications in the region of 100 milliohms. The finite drain-source resistance implies that a small amount of power is wasted in this channel while power is applied to the switched group of devices. #### **Clock Control** The clock control module controls the speed of the system clocks. Where the notebook system has a synchronous ISA clock, it is derived directly from CLK2, the processor clock. The clock control outputs can be fed directly to a frequency generator such as an AVASEM AV9127 where pins are committed to encode a frequency select scheme. The scheme employs two programmable clock generators; one with eight preset frequencies used for the system clock; and the other with four preset frequencies used for the mass storage subsystem. Figure 6 shows the interconnection between the clock control port and frequency generator. By changing the assignments of the encoded select lines, the system clock frequency can be reduced. Frequency generators employ analog voltage controlled oscillators which, when instructed to change frequency, will steadily and gradually change frequency in a smooth transition. This scheme does not violate the minimum high and low times for the core logic devices. #### **Timers** The timers should run independently of the keyboard scanning function. The timers are used as timeouts for a combination of external events or activities. The timers are constructed of reloadable timers and reloaded by transitions or conditions on external events. A typical timeout period is between 1 and 4 minutes, therefore the timeout must be constructed from both timer hardware and support software. Figure 7 shows the interrelationships between hardware and software. The software must record the instances of timeout cycles. If the number of cycles is allowed to reach a predetermined number, the timeout elapses and the assigned power control output is negated, or the clock control outputs proceed to the next state. The count of the number of cycles is reset by a command for the activity monitor. The activity monitor asserts flags during the background and interrupt tasks. The timer software processes these flags to determine the state of the timeout. The software uses a count variable to measure the instances of the timer elapsing and a flag to determine whether activity has occurred. #### **Activity Monitor** The activity monitor sets the activity flags for the timers. The monitors contain combinatorial elements which poll an external activity or a number of external activities. External activity can be detected by transitions or levels on input port pins. The interrupt pins would be better suited for transition detect while the general input ports could be used to poll for external conditions. There are several key activity indicators on the PC. See Table 1 below. Table 1. Key Activity Indicators | SIGNAL | TYPE | DEVICE/PERIPHERAL | | |-----------|-------|--------------------------------------|--| | *IDECS1 | LEVEL | Hard Disk IDE interface chip select | | | *IDESC0 | LEVEL | Hard Disk IDE interface chip select | | | *VWE | EDGE | VGA Memory Write enable signal | | | *FDCS | LEVEL | Floppy disk digital control register | | | *LPTRDY | LEVEL | Parallel printer interface flag | | | *GPRD | EDGE | Accessory interface select | | | *53C90SEL | EDGE | SCSI interface chip select | | | *LIDSW | LEVEL | Notebook lid switch | | "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller AN436 Figure 4. Internal Power Management Elements Figure 5. Power Control Circuitry Figure 6. Clock Control Circuitry Philips Semiconductors Application note # "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller AN436 Figure 7. Hardware-Software Interrelationships #### **Suspend Control** During the suspend state, power is removed from all the system devices except the power management controller and system memory. Before the system is allowed to enter the suspend state, the BIOS empties all the DMA holding registers, makes a copy of the CPU registers and stack pointer into reserved main memory. The VGA memory is also copied into main memory. Once this transaction has been completed, the system BIOS instructs the power management controller to enter the suspend state. At the start of the suspend state, the microcontroller takes over the memory refresh. This is achieved with the use of an external refresh mux. The mux is switched over to the microcontroller refresh lines when REFSEL is asserted. Switchover must only be executed after the system memory controller has performed a complete refresh cycle (512 / 1024 rows). The external multiplexer asserts all the individual \*CAS lines while switched over to the controller. The \*RAS lines are all driven by a single \*REFRESH command from the controller. #### **Battery Monitor** The ADC can be used to monitor the battery condition via an external resistor divider. This monitor can be used to assess the condition of the system batteries during system use and while being charged. A simple "minus delta V" algorithm may be implemented to measure the slope of the battery voltage over time. The charging curve of Figure 8 shows the characteristic of the voltage across the NiCAD cells with a constant current applied. As the NiCADs become charged, the internal temperature of the cells rises and thus their internal resistance increases. This results in a droop of the voltage across the cells. The charging current must be terminated when a droop of greater than 50mV per cell over 1 second is detected. This minus delta V algorithm can be implemented in the microcontroller software. The analog to digital controller can be used to sample the NiCAD battery voltage level at regular intervals. The sample is compared against the last sample for a negative result. If the magnitude of the result is greater than 50mV per cell, then the charging circuit must be given a command to switch off. A battery condition detector can also be implemented in the microcontroller. This detector can be used to give an early indication of an exhausted battery. When a NiCAD cell reaches its supply capacity, the voltage across the cell drops rapidly, thus the system supply can only sustain the core logic for a matter of seconds. The battery condition monitor should give the system and user an early indication of this condition. This can be implemented by monitoring the battery voltage. When a preset slope or level is reached or exceeded, the controller can issue an NMI to the core logic. The core logic can execute a shutdown routine which saves the state of the machine on the hard disk and preserves the integrity of the user's data. June 1991 # "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller AN436 #### **PERFORMANCE** Table 2 shows the power performance of the 83/87C752 in a typical notebook system. During each power management state, the core logic system and peripherals demand lower and lower power as the clock speeds are reduced, resets are asserted and power is removed from the device or peripheral. During the suspend mode, power is completely removed from the core logic devices and peripherals, only the DRAMs remain energized so that the system state can be restored to the next post suspend cycle on the detection of an activity. The FULL-ON figures are maximums, In reality, the processor executes sporadic scripts and then idles in tight loops awaiting IO. This means that the actual power required by the system under normal conditions will be lower than that estimated in that column of the table. Table 2. | STATE DEVICE | FULL-ON POWER (W)<br>(MAX) | SHUTDOWN-DOZE (W) | SLEEP POWER (W) | SUSPEND POWER (W) | |----------------------|----------------------------|-------------------|-----------------|-------------------| | Am386SX | 2.14 | 0.7 | 0.5 | 0.14 | | DRAM + Controller | 1.7 | 0.6 | 0.4 | 0.025 | | Local bus controller | 0.3 | 0.3 | 0.2 | 0 | | ISA bus controller | 0.2 | 0.18 | 0.07 | 0.2 | | 87C752 | 0.08 | 0.08 | 0.08 | 0.015 | | BIOS ROM | 0.11 | 0.002 | 0.002 | 0 | | Floppy drive | 3.1 | 0.035 | 0.035 | 0 | | IDE drive | 3.3 | 0.68 | 0.68 | 0 | | VGA controller | 2.1 | 1.6 | | 0.015 | | Keyboard controller | 0.7 | 0.6 | 0.4 | <b>0</b> , | | Keyboard | 0.15 | 0.15 | 0.15 | 0 | | Oscillators | 0.1 | 0.1 | 0.1 | 0 | | RS232 buffers | 0.11 | 0.002 | 0.002 | 0 | | LCD panel | 0.7 | 0.62 | 0.2 | 0 | | Backlight | 1.5 | 1.5 | 0.1 | 0 | | TOTALS | 15.69 | 6.709 | 4.119 | 0.055 | The gradient of power performance across the states is quite steep, especially when transitioning from the sleep to the suspend states. Table 3. | | FULL-ON | 1/2 CLK2 SHUTDOWN-DOZE | 1/ <sub>4</sub> CLK2<br>SLEEP | SUSPEND | | |---------------------|---------|------------------------|-------------------------------|---------|--| | CPU | ON | ON | ON | OFF | | | DRAM | ON | ON | ON | ON | | | Local bus | ON | ON | ON | OFF | | | ISA bus | ON | ON | OFF | OFF | | | 87C752 | ON | ON | ON | ON | | | BIOS ROM | ON | OFF | OFF | OFF | | | Floppy | ON | ON | OFF | OFF | | | IDE drive | ON | IDLE | OFF | OFF | | | VGA | ON | ON | ON ON | | | | Keyboard controller | ON | ON | ON | ON | | | Keyboard | ON | ON | ON | OFF | | | Oscillators | ON | ON | ON | OFF | | | RS232 buffers | ON | OFF OFF | | OFF | | | LCD panel | ON | ON OFF | | OFF | | | Backlight | ON | ON | OFF | OFF | | Note that the panel and backlight are off during the sleep state. # "Opti-Mizer" power management for notebook computers using the 8XC752 microcontroller AN436 # OTHER INTEGRATION OPPORTUNITIES The 83/87C752 offers a complete power management solution as described above. The functionality and IO capability of this device can be used as a common denominator for other, larger Philips microcontrollers. The 83/87C552 offers the same internal functionality while providing more integration capabilities with its increased IO, memory and timer functions. An example of an integration opportunity would be to combine the keyboard scanner function with the power management function. The Philips 83/87C552 microcontroller is ideal for this task. The microcontroller can implement the scanning and code generation schemes associated with the keyboard function, implement the activity monitors, timers and power control scheme required for power management as well as provide an integrated solution to battery condition detection by exploiting the onboard A/D converters. The PC keyboard scanner is traditionally an 8051 microcontroller. The keyboard scanning and code generation can be performed by an 8051 running at 6MHz. A 12 or 16MHz 83/87C552 microcontroller would have the bandwidth to take on other tasks. Figure 9 shows the 83/87C552 integrated as a power management unit and keyboard Other members of the Philips family of 8051 derivative microcontrollers can also provide an integrated solution to power management (see Table 4). As can be seen, the 83/87C550 provides an intermediate solution to the 83/87C552 and 83/87C752. It has more memory and IO than the 83/87C752 and has three more ADC channels. Table 4. Microcontrollers with A/D | DEVICE | ROM | RAM | A/D | 1/0 | PWM | TIMERS | |-----------|-----|-----|----------|-----|-----|--------| | 83/87C550 | 4k | 128 | 8 8-bit | 24 | 0 | 2 | | 83/87C552 | 8k | 256 | 8 10-bit | 48 | 2 | 3 | | 83/87C752 | 2k | 64 | 5 8-bit | 21 | 1 | 1 | Figure 8. Battery Characteristics Figure 9. Further Integration Opportunities ### 87C751 fast NiCad charger **AN439** #### DESCRIPTION This application note describes a portable standalone, automatic constant current NiCad battery charger using the Philips Semiconductors 87C751 microcontroller. This unit will fast charge NiCad batteries from a 12V source such as an automobile battery or a DC power supply. The charge current is 2.5A which is suitable for charging NiCad cells of 1200mAh capacity in little over 1/2 hour. Use of a microcontroller provides complete flexibility of design parameters such as the number of cells, their capacity and charge rate requirements. A number of key microcontroller techniques described in this application note are a state machine, a low-cost, high-resolution single slope analog-to-digital converter comprised of the microcontroller and a comparator as well as an analog control system. As shown in the block diagram (Figure 10), the charger consists of the 87C751, a switching charge current regulator, an analog-to-digital converter and some LED indicators #### **DESIGN OBJECTIVES** The goal of this design is to achieve a maximum charge rate without damage to the NiCad cells. To determine the requirements for such a charger, we need to examine the most important characteristics of NiCad cells, As a NiCad cell charges, gas bubbles are released from the electrolyte and accumulate on the plates, reducing the effective plate area and increasing cell impedance. When the cell gets near full charge the rate of gas generation and temperature rise increase, since the charge current produces gas rather than stored charge. At that point the process goes into thermal runaway. The cell pressure rises sharply causing the case to vent. A large enough venting can destroy the cell immediately. If the venting is of a lesser magnitude, as would be the case with a relatively low charge current, the cell capacity is reduced. The standard technique is to charge the cells at such low current that there is no risk of thermal runaway. The electrolyte then reabsorbs the gas bubble at the same rate as they are generated. Usually this implies a charge current of 0.1 times the cell capacity and a charge time of 16 hours. We want to achieve full charge in about half an hour. Slow charging also increases the likelihood of dendrite formation. Dendrites are crystalline fingers that can propagate through the plate separators and short the cell internally. Fast charging tends to clear these shorts before they have a chance to become significant. #### **CHARGE TERMINATION** There are two methods commonly used for terminating NiCad fast charges: delta-peak voltage detection and delta-temperature detection. This charger uses the delta-peak voltage method. It is simpler to implement, especially if interchangeable battery packs are to be charged, because the temperature sensing method requires a temperature sensor to be attached to the battery pack. The temperature change in the battery pack depends on how well the pack is thermally coupled to its surroundings, which also makes temperature sensing somewhat tricky. The voltage on a NiCad pack rises during charging, steeply at first, and then at a lower rate. When the pack is nearly full, the voltage rate of rise increases a little, then falls to zero as the voltage peaks. As the pack goes into over-charge the voltage starts to drop and the internal temperature and pressure rise. A typical voltage drop used for charge termination is 1% of the peak voltage as shown in the battery voltage waveform (Figure 11). This charger uses 1% of the measured peak voltage as the threshold, which means that it can charge any number of cells from 1 to 6 without any external input to select a number of cells. # THE 87C751 MICROCONTROLLER The Philips Semiconductors 87C751 contains a 2k byte ROM, a 64 byte RAM, 19 I/O lines, a 16 bit auto-reload timer, a five-source fixed-priority interrupt structure, a bidirectional I<sup>2</sup>C serial bus interface and an on-chip oscillator. In this application note, the timer is used as a 'tick-timer', scheduling events and measuring periods. The ports are used to control and monitor the external analog circuitry. The software is written in C using the Franklin C compiler. Figure 10. Block Diagram Philips Semiconductors Application note Figure 11. Battery Voltage Waveform During Charging #### SOFTWARE #### Scheduler The timer generates events at a fixed interval by updating the variable **tick** in the timer interrupt service routine. The timer is initialized and reloaded with ffff<sub>nex</sub>, which corresponds to a period of 71 milliseconds. The choice of this period is related to the analog-to-digital converter, which is described below. The variable tick is incremented once every 71 ms so that 14 ticks make a second. The scheduler calls the charger procedure when tick equals zero, the leds procedure when tick equals 7 and it resets tick to zero as well as incrementing the seconds variable when tick reaches 14. #### **State Machine** The state machine in the **charger** procedure is the heart of the system. The state machine processes the current state and the filtered battery voltage. Figure 12 shows the topology of the state machine. There are four states: FAULT, INITIALIZING, CHARGING and DONE. The variable state keeps track of the current state. The operation of the states is as follows: #### **FAULT** This is the default state. When the system powers up and is reset, the state variable is initialized with this state. The filtered battery voltage is checked using the **check\_limits** procedure (see Figure 12). If the measured voltage is within a predetermined range, it is assumed that a battery has been connected and the state variable is set to the INITIALIZING state. A voltage out of range will always set the state variable to FAULT no matter what the current state is. #### INITIALIZING During this state the running average noise rejection filter and other variables used by the charging algorithm are initialized by sampling the battery voltage for a preset number of passes through the state machine without making any decisions about the charging process. The number of passes is defined in the constant INITIALIZATION\_TIME which is an integer number of seconds. When the initialization time is over, the state variable is updated to the CHARGING state. #### CHARGING During this state the battery voltage is processed in the **delta\_peak** procedure. A watchdog timer is also used to ensure that the battery is not overcharged in the unlikely event that the **delta\_peak** procedure misses the termination conditions. Until the battery peaks or the watchdog timer times out, the state machine remains in the CHARGING state. If a voltage peak is detected and the voltage drops below the peak by 1%, or the watchdog timer expires, the state variable is updated to the DONE state. #### DONE After MAINTENANCE\_PERIOD seconds, charging current is applied to the battery for 1 second. If the battery voltage falls out of range (i.e., it has been disconnected), the state variable is updated to FAULT, the default state. ### 87C751 fast NiCad charger AN439 Figure 12. Charger State Machine #### **HARDWARE** #### **Buck Converter Current Source** There are two basic converter topologies from which the others are derived. They are the buck and boost converters. As the names imply, the buck converter produces an output lower than its input and the boost converter does the opposite. The transformer isolated versions of the buck and boost circuits are known as the forward and flyback converters. Since the input supply voltage is greater than the maximum expected output voltage and no isolation is required, the buck topology is a good choice for simplicity and high efficiency. The required values of inductors and capacitors for a switching converter are inversely proportional to operating frequency, while switching losses are proportional to frequency, so that a compromise is made in the choice of operating frequency. To keep the converter compact and avoid excessive switching losses, the switching frequency was chosen at 100kHz. The Unitrode UC3843D is a low-cost surface mount current-mode switching power supply controller. In this application, the voltage feedback loop is left open and the controller is driven from its compensation input (pin 1). The UC3843 data sheet shows that this node in the IC is driven by an active pulldown and a fixed 0.5 mA pullup current source. If the voltage feedback, pin 3, is grounded, the internal voltage error amplifier will turn off its output, allowing control of the node voltage by pulling current out of pin 1. The ICL7667 is an inverting MOS gate driver. It provides the correct polarity for the mosfet gate signal and its 1.5A peak output improves efficiency by switching the fet quickly. The Amobead is an optional component which reduces EMI at the expense of increased drain voltage swing. The scope traces were taken without the Amobead in place. #### Analog-to-Digital Converter The analog-to-digital converter consists of Q104, C118, R114, U104 as well as R115, R116 and C119 operating in conjunction with the 87C751. In this application a simple. low-cost ADC with relatively high resolution is required, but it does not need linearity, absolute accuracy or long term stability because the detection method is relative to the peak voltage and happens over a period less than one hour. The circuit functions as a voltage-to-period converter. Although the capacitor voltage follows an exponential curve, it is nearly linear in the operating region from 0V to the comparison threshold of 454mV since the battery voltage which drives it is typically 5 to 6V for a four cell pack under charge. With a single cell the period can stretch to near the 71ms tick period. The capacitor voltage is described by the equation V<sub>C</sub>=V<sub>BATT</sub>(1-e<sup>-t/RC</sup>) where $C=0.1\mu F$ and R=1M in this circuit. The straight line approximation we are using is the tangent to the actual curve at t=0. This can be found by differentiating the above equation with respect to time #### dVC/dt=VBATT/RC . e-t/RC and setting t=0. Then the expression becomes #### dVc/dt=VBATT/RC Integrating the above expression yields a straight line #### V<sub>C</sub>=V<sub>BATT</sub>/RC . t from the origin to the point (RC,V<sub>BATT</sub>). If you solve for t using the straight line and V<sub>C</sub>=454mV, V<sub>BATT</sub>=5.50V, you get t=8.255ms. Substituting this back into the first equation and solving for V<sub>BATT</sub> yields 5.73V, which is within 5% of the actual voltage. The absolute accuracy of the conversion is only important when using the battery voltage measurement to detect a battery connected to the output, versus a short circuit or an open circuit. All the critical sensing is done within 1% of the peak voltage and is relative to the peak. To avoid contamination of the battery voltage reading by switching noise, the voltage sensing is done during a quite period when the switching current source is turned off by the processor. #### **Waveforms** The first trace (Figure 13) shows drain to ground voltage on the P-channel FET. Note that the peak negative voltage is \_17.66V and there is minimal flyback ringing. The positive spike on turn-on may be due to sense resistor inductance. The second trace (Figure 14) shows the voltage across the $0.1\Omega$ sense resistor at a DC output current of 2.5A and an input voltage of 12.2V. Voltage spikes due to trace and sense resistor inductance are filtered out by R105, C112 to prevent false triggering of the UC3843 current comparator. The third trace (Figure 15) shows the FET gate voltage. FET gates are usually rated at ±20V maximum, but reliability is enhanced if the are kept within ±15V. In this case the gate voltage is well within range for reliable operation. #### REFERENCES - Billings, Keith H.: Switchmode Power Supply Handbook, McGraw Hill 1989 - 2. Unitrode I.C. Data Handbook, Unitrode Corp. 1990 - 3. Panasonic NiCad Battery Handbook Figure 13. First Trace Figure 14. Second Trace Figure 15. Third Trace Figure 16. Schematic Diagram of Battery Charger (1 of 2) Figure 16. Schematic Diagram of Battery Charger (2 of 2) ## 87C751 fast NiCad charger AN439 ``` #pragma PL (60) #pragma PW (120) #pragma OT (3) #pragma ROM (SMALL) #include <req751.h> typedef unsigned char byte; typedef unsigned short word; typedef unsigned long dword; #define TRUE #define FALSE 0 #define ON 0 #define OFF 1 #define FLASH /* parameters */ #define ONE_OVER_DELTA 128 #define ONE_SECOND /* timers */ /* 1 cpu cycle = 1.085uS */ /* 1 tic = 0xffff cpu cycles */ /* 1 "second" = 14 tics = 995.5uS */ #define MAX_BATT_PERIOD 5530 /* 60ms period, 0.9 volts */ #define MIN_BATT_PERIOD 430 /* 4.67ms period, 10 volts */ #define DEAD_MAN_TIMEOUT 2712 /* 45 minutes */ #define MAINTENANCE_PERIOD 500 /* 1 pulse in 500 Seconds */ #define INITIALIZATION_TIME 20 /* errors */ #define BATTERY_VOLTAGE_OUT_OF_RANGE 0x01 #define BATTERY_CHARGED 0x02 #define DM_TIMEOUT 0 \times 03 /* states */ #define FAULT 0 \times 01 #define INITIALIZING 0 \times 02 #define CHARGING 0 \times 03 #define DONE 0 \times 04 /* global variables */ byte byte state; word seconds: word this_period; word last1; word last2: word last3: word last4; word last5; word last6; word last7; word valley; sbit /* P1.0 */ comp_out = 0x90; sbit clear_cap = 0x93; /* P1.3 */ sbit charge = 0x97; /* P1.7 */ sbit fault_led = 0x80; /* P0.0 */ sbit charge_led = 0x82; /* P0.2 */ ``` #### AN439 ### 87C751 fast NiCad charger ``` word measure_batt(void) { byte tic_now; word interval; tic_now = tic; interval = 0; clear_cap = FALSE; while(!comp_out && tic==tic_now) interval++; clear_cap = TRUE; return (interval); } byte check_limits( word batt_period ) { if ((batt_period > MIN_BATT_PERIOD)&&(batt_period < MAX_BATT_PERIOD)) {</pre> return(FALSE); } else { return(BATTERY_VOLTAGE_OUT_OF_RANGE); } word filter ( word ) { word temp1, temp2, temp3, temp4; word result1, result2; temp1 = ((last0 / 2) + (last1 / 2)); temp2 = ((last2 / 2) + (last3 / 2)); temp3 = ((last4 / 2) + (last5 / 2)); temp4 = ((last6 / 2) + (last7 / 2)); result1 = ((temp1 / 2) + (temp2 / 2)); result2 = ((temp3 / 2) + (temp4 / 2)); last7 = last6; last6 = last5; last5 = last4; last4 = last3; last3 = last2; last2 = last1; last1 = last0; return((result1 / 2) + (result2 / 2)); } byte delta_peak ( word period ) { if (period < valley) valley = period; if (period > (valley + (valley/ONE_OVER_DELTA))) return (BATTERY_CHARGED); else return (FALSE); } byte watchdog ( word now ``` ## 87C751 fast NiCad charger AN439 ``` { if (now < DEAD_MAN_TIMEOUT) return (FALSE); else return (DM_TIMEOUT); } void charger ( void ) { this_period = measure_batt(); this_period = filter(this_period); switch (state) { case FAULT: { if (!check_limits(this_period)) { seconds = 0; state = INITIALIZING; } else state = FAULT; break; } case INITIALIZING: { if (check_limits(this_period)) state = FAULT; else { charge = TRUE; if (seconds < INITIALIZATION_TIME) state = INITIALIZING; else { valley = 0xffff; state = CHARGING; } break; case CHARGING: { if (check_limits(this_period)) state = FAULT; else { if (!watchdog(seconds)) { if (delta_peak(this_period)) { state = DONE; seconds = 0; } else { state = CHARGING; charge = TRUE; } } else { state = DONE; seconds = 0; } } break; } case DONE: { if (check_limits(this_period)) state = FAULT; ``` ``` else { if(seconds < MAINTENANCE_PERIOD) { charge = TRUE; seconds = 0; state = DONE; } break; } } void leds ( void ) { switch (state) { case FAULT: { charge_led = OFF; fault_led = ON; break; } case INITIALIZING: { charge_led = ON; fault_led = OFF; break; case CHARGING: { charge_led = ON; fault_led = OFF; break; case DONE: { charge_led = !charge_led; fault_led = OFF; break; } } /* Timer 0 interrupt */ void timer0(void) interrupt 1 { tic++; } void main() { /* initialize pins */ charge=FALSE; charge_led = OFF; fault_led = OFF; /* initialize timer */ TR=1; CT=0; GATE=0; RTH=0; RTL=0; ITO = TRUE; ET0=1; EA=TRUE; /* initialize globals */ tic=0; seconds = 0; valley = 0xffff; state = FAULT; ``` } ## 87C751 fast NiCad charger AN439 ``` /* main program scheduler */ while(1) { (tic) { case 0: { switch (tic) { { charger(); while (tic < 1); break; } case 7: { leds(); while (tic < 8); break; case ONE_SECOND: { tic = 0; seconds++; break; ``` June 1993 **AN442** #### SUMMARY BCM87C751 is a powerful, flexible and low cost Digital Controlled Monitor System, based on the 87C751 microcontroller. It employs I<sup>2</sup>C bus control with various I<sup>2</sup>C bus controlled peripherals (PCF8582EP-EEPROM and TDA8444 D/A converter). The control function is implemented via 8 6-bit DC voltage output from TDA8444. Some features of the system: - Flexible approach, especially for multisync or auto sync operation - Mode detection and frequency measurements by microprocessor - · Mode switching under software control - · Elimination of potentiometers - Quick factory alignment (DACs can be preset) - · Automatic factory alignment possible This document describes the operation and the use of the system. it provides necessary information concerning operation, required hardware, flow charts and their effect on the performance. #### INTRODUCTION Figure 1 shows the block diagram of a high-performance color monitor with microcontroller and several parts that communicate via the two-wire I<sup>2</sup>C-bus. The system can perform the following: - Determine the mode and standard of incoming signals with the stored values in memory (e.g., multisync modes). - Enter parameters of user defined modes into memory via a keyboard. - Control analog parameters such as contrast and brightness via the bus from keyboard inputs. - Control mode and standard parameters (such as picture geometry parameters and the free-running oscillator frequency). #### **Features** - · Multisync or Autosync operation - FH = 31kHz-95kHz - FV = 50Hz-114Hz - Selectable four or five function control configurations - Selectable one digit, or one and one-half digit, or null seven segment mode display. - Selectable Horizontal direct ratio or indirect ratio F to V converter DAC output configurations - Selectable ten user modes plus ten factory modes, or, one user mode plus 19 factory modes configurations - Selectable multiple up/down keys or minimum keyboard configuration - Change function without save key, all keys but the reload key have a repeat function - Both Horizontal and Vertical outputs have F-to-V converter DAC outputs Four outputs of Horizontal PLL capacitor selection signal. This can be easily adapted for further extension. #### IC DESCRIPTIONS #### 87C751 A derivative of the 8051 family of microcontrollers, the 87C751 has an 8-bit CPU, 2k bytes EPROM, 64 bytes RAM, 19 I/O lines, a bi-directional inter-integrated circuit (I<sup>2</sup>C) serial bus interface, and an on-chip oscillator. #### PCF8581/2 A 1k- or 2k-bit, 5V electrically erasable programmable read only memory (EEPROM) organized as 128 or $256\times 8$ bits. The stored information is electrically alterable on a word-by-word basis, I<sup>2</sup>C-bus controlled. #### TDA8444 Comprises eight DACs, each controlled via the I<sup>2</sup>C-bus. The DACs are individually programmed using a 6-bit word to select an output from one of 64 voltage steps. the maximum output voltage of all DACs is set by the input VMAX and the resolution is approximately VMAX/64. For detailed information on these devices, please refer to their respective data sheets. Figure 1. Block Diagram of Bus Controlled Monitor System BCM 87C751 AN442 #### **OPERATION INSTRUCTION** #### **Function Selection and Change** When the monitor is powered on it will automatically enter the corresponding mode depending on the input signal. Different configurations and functions can be defined by users with the use of different features. The following configuration's functions are examples for user's reference. See Figure 2 for Configurations 1 through 4. To adjust functions such as V-size, V-shift, H-center, H-shift, and PCC (Pincushion Correction Circuitry): - The "Function" key should be pressed until the required function LED is lit. - 2. If the V-shift LED is on, the user can then adjust V-shift by pressing Up or Down key. If the Up key is pressed, the V-shift DAC output will increase one step. While the Down key is pressed, the V-shift DAC output will decrease one step. The user can repeat the Up or Down key simply by pressing it longer than 0.5 second. It will then automatically repeat approximately 2 times per second until the key is released. # Mode Selection and Change (See Figure 4) In Figures 3 and 4. the mode number is displayed on the two seven-segment LEDs. Each number denotes one mode. Modes 10 through 19 are user modes, which can be defined by the user. When there is a new mode entering the monitor that does not belong to any mode stored n the EEPROM, the mode display will show "19". If the user presses the Reload key while the mode display is "19", the display will flash. When the mode display is flashing, the user can select the destination mode by pressing the Up/Down keys. The destination mode is between 10 and 19. Every press of the Up key causes the flashing display to add one, unless it already reached 19. Every press of the Down key causes the flashing display to subtract one, unless is has reached 10. When the user lets the destination mode flash on the display, the user can press the Reload key to store the new mode to destination mode. When the mode display stops flashing, the new mode is stored. The newly stored destination mode is permanent, unless the user repeats the entire procedure. To change an old user mode, already stored in EEPROM, to a different user mode, press the Reload key for longer than 8 seconds while the monitor is working in the old mode. The mode display will flash the old mode, then the user can use the Up/Down key to select the new mode. Press the Reload key again to copy the old to new destination user mode. If the user forgets to press the Reload key again, the flashing of the mode display will last for 2 minutes, then the program will cancel the copy old mode to new user mode command. During the flash period, the program still monitors the Horizontal and Vertical sync signal to adapt the DAC to the proper mode. For example, while the user tries to copy new mode 13 to mode 15, and the mode display 13 (15) is flashing, if the PC sends out a signal for mode 3, the program will change the DAC output to adjust the monitor to work in mode 3, but the mode display is still flashing on user mode 13 (15) and the store procedure is still going on until the user presses the Reload key again, or terminates the copy procedure after the 2 minutes time out. The mode display then shows 3. NOTE: Upon request, we can also program in advance those 10 user-defined modes that can still be changed by the user if necessary for further extension. For Configuration 5 to Configuration 8, see Figure 3. To adjust functions, the user can simply press the corresponding push button. The upper push button will increase the DAC output. The lower push button will decrease the DAC output. (A total of 64 steps can be programmed in advance.) Figure 2. Control Panel Figure 3. Control Panel | | | MODE | | | | | H.P. | V.P. | | and the second second | |--|--|--------|--------|-------------------|-----|----|------------|----------|--|-----------------------| | | | 0 | VGA-1 | | 31k | 70 | + | _ | | | | | | 1 | VGA-2 | nan est | 31k | 70 | <u> 15</u> | + | | | | | | 1<br>2 | VGA-3 | . 3 mar. | 31k | | | | | Table State | | | | 3 | 8514A | Section 1 Section | 35k | 87 | + | + | | | | | | 4 | SVGA-1 | | 35k | 56 | <br>+ | + 44 | | | | | | 5 | UVGA-1 | | 48k | 60 | + | + | | | | | | 6 | VESA | | 56k | 70 | | _ 1 kg 1 | | | | | | 7 | V64-1 | | 64k | 60 | + | + | | | | | | 8 | SVGA-2 | | 37k | 60 | + | + | | | | | | 9 | V78 | | 78k | 60 | + | | | | | | | 10 | USER D | EFINE | | | • | • | | | | | | • | • | | • | | 1 | . • | | | | | | 18 | | | • | • | | | | | | | | 19 | | | | | | • | | | Figure 4. Mode Selection AN442 # SOFTWARE FLOW CHART DESCRIPTION (See Figures 5 through 7) When power is on, software initializes the hardware first. The microcontroller waits 100µs for the settlement of the hardware, then initializes itself by specifying stack, setting timer, clearing RAM, arranging interrupt, . . . , etc. Figure 5. Main Flow Chart AN442 Figure 6. Function Selection Flow Chart Figure 7. Mode Detection Flow Chart AN442 Table 1. | | ADD DIODE | REMOVE DIODE | |----|-----------------------------------------------------|------------------------------------------------| | D1 | Indirect ratio of VCO output<br>(JP4)—See Figure 8. | Direct ratio of VCO output (JP4)—See Figure 8. | | D2 | 10 user modes<br>10 factory modes<br>(JP5) | 1 user mode<br>19 factory modes<br>(JP5) | | D3 | 4 adjustable functions (JP6) | 5 adjustable functions<br>(JP6) | | D4 | Multiple Up/Down keys<br>(JP7) | Single Up/Down keys<br>(JP7) | Referring to previous section, Function Selection and Change, software can detect the hardware configuration by pulling 87C751 microcontroller pin P0.2 LOW to read the diode arrangement. Each diode denotes one change in the hardware configuration. Table 1 explains the usage of each diode. After the configuration detection, then it goes to check EEPROM status. If the EEPROM is blank, the program will start to move all factory set data from the microcontroller's PROM to EEPROM. The last byte datum in the microcontroller's PROM is 66 used for blank check. First it reads address DD in the EEPROM, then compares it with 66. If they are equal, the software will skip the EEPROM program procedure. If they are not equal, the software will program the EEPROM. This means that monitor makers can define their own factory modes by programming the EEPROM in advance. The following programs are endless loops. Please refer to the main flow chart (Figure 5). There are three tasks in the endless loop. The first task is Function Selection, basically a keyboard process program. The second task is Mode Detection, which includes search mode and change mode. The third task is Mode and Function Display, which includes flash mode display. AN442 #### **Mode Detection** Beginning with branch "B", Mode Detection Flow Chart (Figure 7), the block at the top of the flow chart is "Read Previous Mode" (the time before 0.5 second ago) and includes Horizontal Sync Frequency, Vertical Sync Frequency, Horizontal Sync Polarity, and Vertical Sync Polarity. The second block is a comparison test block. When current mode (from 0.5 second ago until now) parameters are the same as those in previous mode, the program will branch to the right test block. Since the mode is not changed, the second test block in the right part of the flow chart will branch to leave the Mode Detection section. If the current mode (from 0.5 second ago until now) parameters are not the same as the previous mode (the time before 0.5 second ago), the first test block from the top of the flow chart will branch to search all mode parameters in the EEPROM to find out what the current mode should be. The left loop of the flow chart checks for the end of the search procedure, i.e., if all modes in the EEPROM are searched and checked, and the outcome is the same, then this test block will branch to set up a new user mode (19), as per the 4 steps indicated in the central flow chart line. The first step in setting up a new user mode is to "Put New Parameters" (such as Horizontal Sync Frequency, Vertical Sync Frequency, Horizontal Sync Polarity, and Vertical Sync Polarity) into the EEPROM. The new mode parameters are always saved in the last mode address. If the configuration allowing 10 user modes is selected, then diode 2 is added. If one was found to be the same, the program will branch to the right test block. If it then finds that there is a mode change, it will branch to Reload Mode Data to DAC to complete the mode change procedure. When the mode change procedure is completed, the monitor will be working in a new mode. Since the program enters the Mode Detection task every 0.5 second, it takes from 0.5 to 1.0 second to finish the change of mode. To save the new user mode (mode 19) to other user mode (10-18), the user can use the RELOAD key to save the new user mode to other user mode (modes 10 through 18). If the configuration for 10 user modes is selected, it is highly recommended that you save new user mode to other user mode (10-18) because the last mode "mode 19", will be overwritten by any new user mode whenever a new user mode is detected, after new user mode parameters are detected. The second step in setting up a new user mode is "Calculating VCO Output Value" (see Figure 8). There are two different curves for the designer to select. If diode 1 is removed, the VCO Output Voltage will be in direct ratio to the Horizontal Sync Frequency. If diode 1 is added, the VCO Output Voltage will have an indirect ratio. The third step in setting up a new user mode is "Put VCO Value to EEPROM". The last step is "Reload Mode Data to DAC". After reloading the DAC, the monitor is changed to the new user mode. Figure 8. Horizontal VCO Output Application note Philips Semiconductors ## (BCM) 87C751 Specification for a bus-controlled monitor AN442 #### **Key Function Selection** The first task is Function Selection (see Figure 6). When the program scans the keyboard, it first checks for the function key. If it is depressed, the program will branch right to change function VALUE(+1). the function LEDs are lit in sequence, i.e., when the second LED is lighting and the program detects a press in function key, the program will light the third LED and turn off the second LED. If the program detects that the last LED is lighting, it will turn on the first LED and turn off the last LFD. If the key pressed by the user is not a function key, the program will check if it is the reload key. If it is not, then the second test block will branch left to check Up/Down keys. both the Up and Down keys have two different definitions. When the user is updating function contents, Up and Down keys are used to change the function contents stored in the EEPROM. In that situation, the flash flag is not set; after the program branch left from the reload key test block, the program will test flash flag, then the program will change the output of DAC. If a flash flag is set (see next paragraph, also), Up and Down keys will change the flashing mode displayed on two seven-segment LED displays. The flashing mode is valid between 10 and 19. The Up key will add one to the flashing mode unless the flashing mode is already 19, while the Down key will subtract one unless the flashing mode is already 10. If the reload key is pressed while the program is in last mode (19), i.e., a new mode which is not the same as any mode entered in the EEPROM, the program will check to see if this is the first press. If this is the first press, the fourth test block in the middle will branch right to set the flash flag, after the flash flag is set, the mode displayed on the two seven-segment LED displays will start to Between the first press of the reload key and the second press of the reload key, the Up and Down keys can be used to change the flashing mode to a destination mode. When the program detects the second press of the reload key, the program will execute all the center blocks in the flow chart. First, starting to clear the flash flag; second, to get last mode data from EEPROM; and third, to put the mode data into a new address. The destination is decided by the user via Up and Down keys to select flashing mode, then pressing the reload key to make the flashing mode be a still mode. After mode display is still, the user finishes defining the destination user mode. This destination user mode will last forever unless the reload key is used to redefine it. If the user presses the reload key, and the program is not in the last mode, it will branch right to reset mode data in EEPROM, starts to read original mode data in microcontroller's PROM, then puts these data to EEPROM, the outputs to DAC. This function is to help the user to restore the monitor when the monitor display is out of control. For example, if the user adjusts the Horizontal phase too broad, then monitor may become out of sync. As a consequence the screen will be a mess, and it is not easy for the user to re-adjust for correction. This feature will minimize possible complaints from customers. #### CIRCUIT DESCRIPTION U1-87C751 is an 8-bit microcontroller and the heart of the Bus-Controlled Monitor. The 87C751 receives Vertical Sync and Horizontal Sync signals from pins P1.5 and P1.6. The R3,C5 in pin P1.5 is a low pass protection circuit. It can prevent the Vertical Sync signals, including Horizontal Sync Pulse, from interfering with the counting of the Vertical Sync Frequency. The R2 in pin P1.6 is only used for protection of 87C751. The 87C751 automatically checks the mode parameters from these two pins, then switches the DAC from the old mode to a new mode. When 87C751 is checking the mode, it reads different mode parameters from the EEPROM via I2C bus, then decides whether there has been a change in mode. If a change is needed, the 87C751 will first mute video by sending a LOW to pin P0.2, then reads the correct mode data from the EEPROM via the I2C bus. It then puts the data to the DAC via I2C bus. Because of the I<sup>2</sup>C bus, the connections between the EEPROM, DAC, and the microcontroller are very simple. The system clock is provided by a 12MHz crystal connected to Pins 10, 11 of the 87C751. Basically, port1 is used for input, but P1.4 and P1.7 are used for output. P1.0 to P1.3 are used for keyboard and configuration input. Port0 has only three pins; P0.0 and P0.1 are used for I2C control. P0.2 is an output pin used to test configurations. Port3 is basically used for output; P3.0 to P3.4 are used for mode seven-segment LED display output; P3.5 to P3.7 are used for function display. Both mode display and function display need extra decoders, an HEF4511B seven-segment display driver is used to display the mode, while an HEF4556B dual 2-to-4 decoder is used to display function LEDs. PCF8582 is a 2k-bit EEPROM. R4,C1 constructs an external R-C time to program the EEPROM. In normal operation the 496 EEPROM needs 30ms to program one byte. C2 is a decoupling capacitor to stabilize the DC supply voltage for PCF8582. TDA8444 is an octal 6-bit DAC. R7,VR5,C# constructs a reference voltage to define the DAC's maximum output voltage. In practice, the reference voltage must be below 10.5 volts, so R7 is added to prevent the reference voltage from exceeding that limit. C4 is also a decoupling capacitor to stabilize the DC supply voltage for TDA8444. The upper half of the HEF4556 is used to provide a switch signal to select Horizontal OSC time constant capacitors. The four outputs are Active-LOW. When the Horizontal Sync Frequency (H.S.F.) falls in one of the four ranges, the corresponding output pin will go low. The four ranges are: (H.S.F. < 35kHz), (35kHz < H.S.F. < 40kHz), (40kHz < H.S.F. < 50kHz), (H.S.F. > 50kHz). The enable input in the upper part of the HEF4556B can be used to extend the upper limit of the switch signal. The lower part of the HEF4556B is used to display function LEDs, the fifth LED is driven by an NPN transistor. When the transistor is turned on by the microcontroller, it also disables the lower part of the HEF4556B. If multiple Up/Down keys are configured, the function LEDs are replaced by five pairs of Up/Down keys. Because the tenth digit of the mode display is either "1" or blank, the driver of the tenth digit uses only one transistor. The driver of the base digit employs an HEF4511B, it is a BCD seven-segment display driver with output Active-HIGH, so only common cathode types can be used. The factory can use one LED to replace a BCD display. When the LED is lit, the BCD display can display user mode, or factory mode. This is one way to reduce the system cost. If multiple Up/Down keys are not configured, the keyboard has four keys: Function key, Up key Down key Reload key. If multiple Up/Down keys are configured, there will be no function key, but five pairs of Up/Down keys and one Reload key, the multiple Up/Down keys are configured by adding a diode in JP7. If adding a diode in JP6, there will be only four functions available, i.e., there will be only four pairs of Up/Down keys or four function LEDs. LM7805 is a power regulator IC, it changes 12V to 5V to supply the whole circuit except TDA8444, which uses a 12V power supply to provide a wider range of DAC output. Application note Philips Semiconductors ## (BCM) 87C751 Specification for a bus-controlled monitor AN442 There is a table to explain the usage of each pin in the JP1 socket. JP2 and JP8 are connected together, JP3 is only used for future automatic alignment (including production line) if necessary. JP4 to JP7 are used to select hardware configurations as previously mentioned. #### SPECIFICATION OF THE SYSTEM - 1. The input signals to the system are Horizontal Sync and Vertical Sync. The system accepts standard TTL level signals, i.e., $V_{IH} > 2V$ , and $V_{IL} < 0.4V$ . Horizontal Sync tolerance is ±0.5kHz, and Vertical Sync tolerance is +2/-2 Hz. - 2. There are eight DAC output signals. Their maximum output voltage can be preset by setting a voltage on the TDA8444's VMAX pin. The voltage on the V<sub>MAX</sub> pin must be below 10.5V and also below the voltage on the TDA8444's Vp pin. For other detailed output current characteristics, please refer to Philips data books IC02a, IC02b and 80C51 and Derivative Microcontrollers - 3. The Horizontal switch outputs have four pins. they are standard CMOS B-type buffered outputs. They are Active-LOW. i.e., there will be only one output active at any time. If the designers wants to add ranges in higher Horizontal Sync Frequency, the designer can put extra - circuits onto the demo board. For example, an OPA can be added as a comparator to detect the VCO output. If the VCO output is higher than a certain voltage (VCO's 60kHz output voltage), the OPA will be triggered and the upper half of the HEF 4556 can be disabled by the OPA via HEF4556's Pin 1, when HEF4556 is disabled, the four Horizontal switch outputs will remain HIGH, then the OPA's output can be used as another switch output. - 4. Total current consumption is around 25-90mA, depending on the number of LED and seven-segment displays being #### PARTS LIST 87C751 BUS CONTROLLED MONITOR TH-9102/4 Revised: November 7, 1991 Revision: Dogo 1 | l of Materials | | November 7, 1991 | 12:08:46 Page 1 | | | |---------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------|--|--| | ITEM | QUANTITY | REFERENCE | PART | | | | Service of Company | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | r C1%, en large en la | 2700pF | | | | 2 / 2 / 2 / | 6 | C2, C3, C4, C8, C12, C13 | 0.1μF | | | | 3 | 1 | C5 444 (24 ) 1 1 2 44 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | 0.01μF | | | | 4 | 1 | . C6. | 100μF | | | | 5 | 2 | C7, C11 | 1μF | | | | 6 | 2 | C9, C10 | 33pF | | | | ar a ra - 1 ag - <b>7</b> | 5 | D1, D2, D3, D4, D5 | LED | | | | | 3 | JP1, JP2, JP8 | Header 16 | | | | 9 | 1.4 | at JP3 and | Header 4 | | | | 10 - | 4 | JP4, JP5, JP6, JP7 | Jumper (add diode) | | | | 1100 - 20 | 2 | Q1, Q2 | BC548 | | | | 12 | | e <mark>e Ri</mark> elek e di Sa <del>ra</del> go de demonstration de la company | 470R*7 | | | | 13 | 11 | R2, R3, R8, R9, R10, R11, R14, R15, R17, R19, R20 | 470R | | | | 14 | 6 | R4, R6, R12, R13, R16, R18 | 22k | | | | 15 | 1 | R5 | VR10k | | | | 16 | 1 | R7 | 2k | | | | 17 | 2 | R21, R22 | 56R | | | | 18 | 5 | S1, S2, S3, S4, S5 | SW Pushbutton | | | | 19 | 1 | U1 and a second second | 87C751 | | | | 20 | 1 | U2 | HEF4556B | | | | 21 | 1 | U3 | PCF8582 | | | | 22 | 1. | U4 | TDA8444 | | | | 23 | 1. | U5 | HEF4511B | | | | 24 | 1 | U6 | LM7805 | | | | 25 | 2 | U7, U8 | DISP-7 | | | | 26 | 1 | Y1 | 12MHz | | | December 1991 497 Philips Semiconductors Application note # (BCM) 87C751 Specification for a bus-controlled monitor AN442 **PARTS LIST** 87C751 BUS CONTROLLED MONITOR TH-9102/5 Revised: November 13, 1991 Revision: | Bill of Materials | | November 13, 1991 | 15:42:31 Page 1 | | | |-------------------|--------------------------|------------------------------------------------------|-------------------------------|--|--| | ITEM | QUANTITY | REFERENCE | PART | | | | 1 | r girini 🕇 e ngan | C1 - 18-1 - 18-18-18-18-18-18-18-18-18-18-18-18-18-1 | 2700pF | | | | 2 | 6 | C2, C3, C4, C8, C12, C13 | 0.1μF | | | | 3 | 1 | C5 | 0.01μF | | | | 4 | 1 | C6 if every production reverse in the contract of | 100μF | | | | 5 | 2 | C7, C11 | · 1μF (said arrest faur less) | | | | 6 | 2 | C9, C10 | 33pF | | | | 7 | 3 | JP1, JP2, JP8 | Header 16 | | | | 8 | 1 | JP3 (St. St. St. St. St. St. St. St. St. St. | Header 4 | | | | 9 | 4 | JP4, JP5, JP6, JP7 | Jumper (add diode) | | | | 10 | 2 | Q1, Q2 | BC548 | | | | 11 | 1 | R1 | 470R*7 | | | | 12 | 10 | R2, R3, R8, R9, R10, R11, R14, R15, R19, R20 | 470R | | | | 13 | 6 | R4, R6, R12, R13, R16, R18 | 22k | | | | 14 | 1 | R5 | VR10k | | | | 15 | 1 1 | R7 - 12 - 12 - 12 - 12 - 12 - 12 - 12 - 1 | 2k | | | | 16 | 2 | R21, R22 | 56R | | | | 17 | 12 | S1, S2, S3, S4, S5, S6, S7, S8, S9, S10, S11, S12 | SW Pushbutton | | | | 18 | 1 7 | U1 | 87C751 | | | | 19 | anta an <b>t</b> ina sak | U2 | HEF4556B | | | | 20 | 1 | U3 | PCF8582 | | | | 21 | 1 . | U4 | TDA8444 | | | | 22 | | U5 | HEF4511B | | | | 23 | 1 | U6 | LM7805 | | | | 24 | 2 | U7, U8 | DISP-7 | | | | 25 | 1.1 | Y1 | 12MHz | | | December 1991 498 AN442 #### **CIRCUIT DIAGRAM** AN442 #### PRINTED CIRCUIT BOARD ### 87C751 BUS CONTROLLED MONITOR (TH-9102/4) AN442 101.19 1.6/TWT/06 Philips Semiconductors Application note #### (BCM) 87C751 Specification for a bus-controlled monitor AN442 #### **APPENDIX A** #### References - Philips Data Book IC02a, IC02b Video and Associated Systems - Philips Data Book IC20 80C51 and Derivative Microcontrollers Title: "AN422: Using the 8XC751 Microcontroller as an I<sup>2</sup>C bus Master" - Philips Data Book RF Communications Title: "AN168: The Inter-Integrated (I<sup>2</sup>C) Serial Bus: Theory and Practical Consideration", Author: Carl Fenger - Title: "ETV8831: Deflection Processor TDA8433 with I<sup>2</sup>C Control" Author: DJA Teuling - Title: "ETV89008: VGA Monitor with the High Resolution Colour Tube M34ECL10X36" Author: H. Nerhees #### **APPENDIX B** When you want to determine Vtrig signal, please disconnect Pulse Signal Generator (P.S.G.) Output to H. Sync demoboard from monitor and connect, and use input, set P.S.G. to 60kHz, TTL level output, then power on the demoboard, the mode display should display "19", the the voltage in DAC H-V output pin is the trigger level voltage of 60kHz. You can set P.S.G to 70kHz to measure trigger level voltage of 70kHz. December 1991 503 (BCM) 87C751 Specification for a bus-controlled monitor AN442 #### **APPENDIX C** All VRs in this application note can be charged to fix resistors, when proper dividing voltage is determined. Philips Semiconductors Application note ### ACCESS.bus mouse application code for the 8XC751 microcontroller **AN445** #### DESCRIPTION ACCESS.bus is an open standard, defining a system for connecting a number of relatively low speed peripheral devices to a host computer, typically a desktop system. The ACCESS.bus (A.b) standard is driven by the increasing demand of workstation and PC users for more peripherals on the desktop than ever before. Devices range from keyboards, mice and trackballs to hand held scanners, card readers and 'virtual reality' gloves. Some of the problems the A.b standard addresses are: difficulty of linking peripherals by non-expert users, desktop wiring clutter, limited number of I/O ports on a workstation, peripheral compatibility with different platforms and the high cost of software driver development associated with adding new peripherals to a system. At the hardware level, the A.b is based on the I<sup>2</sup>C serial bus developed by Phillips. The I<sup>2</sup>C protocol is supported by standard IC components, including a range of microcontrollers of the 80C51 family. These microcontrollers provide the intelligence for executing the A.b protocol in both peripheral devices and host systems. Many desktop peripherals can be implemented with a single, low cost 8XC751 microcontroller where the firmware supports both the I/O activity and the A.b protocol implementation. This application note shows the 8XC751 firmware of Digital Equipment Corporation's A.b mouse implementation. Many A.b desktop devices could be implemented with a very similar code. After some discussion of mouse operation we shall give a short overview of the A.b protocol. Our discussion of the A.b is by no means complete—please refer to the specifications for more detailed information. #### **MOUSE OPERATION** The mouse is the most popular pointing device for interactive operation with a workstation, personal computer or Windows terminal. It reports to the host two dimensional planar movement, and user's activation of two or three buttons. Many of the mice available today are opto-mechanical, using shaft encoders. As the mouse is moved over its pad, a lightweight rubber ball turns two perpendicular shafts. When the mouse is held with its cable at the top (away from the user), a left-right movement will rotate the 'X' shaft and an up-down movement will rotate the 'Y' shaft. Any diagonal movement will affect both. The shafts rotate slotted encoder disks which intercept light emitted by an LED. For each shaft there are two phototransistors detecting the light, producing two signals which are out of phase by 90 degrees. Figure 1 shows the waveforms produced for one of the shafts when it rotates. The changes in these quadrature signals can be detected to determine the direction of the mouse movement, and its magnitude. The "positive movement" waveforms relate, for example, to a left to right movement in the X direction. Denoting channel samples as 'AB', a transition from a '00' state to '10' shows a positive movement, while a transition from '00' to '01' shows a negative movement. The resolution of a mouse is determined by the number of changes to the quadrature waveforms produced in a unit length of planar movement. This is determined by the mechanics of the mouse, regardless of the speed in which the mouse is being moved. The mouse is an incremental pointing device, giving the host periodical position reports which show the displacement change relative to the last report. The microcontroller in the mouse takes the burden of keeping track of the rapid quadrature waveform changes and computing the relative displacement accumulated for each new position report. The quadrature waveforms are sampled, the changes are determined to be positive or negative, and X and Y relative displacement accumulators are being incremented or decremented accordingly. The average rate of change is determined by the speed of mouse movement. For accurate position reports the encoder waveforms should be sampled frequently enough in order not to miss changes. The DEC mouse produces 200 changes for one inch of movement. Mouse movement at 10 inches per second will yield event rate of 2000 per second, and the microcontroller attempts to sample the encoder waveforms with at least twice that rate-no more than 250 µS between samples. The MAIN routine of the example program performs this sampling in an infinite loop. It reads the position detectors at port 3, compares it to prior readings and if there was a change computes the new value of the relative displacement accumulators YCOUNT and XCOUNT. Position reports are sent to the host at a much slower rate. In this example, Timer0 interrupts the code at the reporting intervals, and its interrupt routine ("Timer0") initiates a message transmission to the host with the latest information if there was some change in the mouse position or the buttons. The Timer0 service routine samples the position of the three mouse buttons sensed on port 1. Button changes are reported to the host in the same message as the position reports. ### ACCESS.BUS PROTOCOL OVERVIEW The A.b communications protocol is layered in three levels. The lowest level is a subset of the Philips Inter-integrated Circuit (I<sup>2</sup>C) bus protocol, above it the A.b Base Protocol common to all types of A.b devices, and on top are the Application Protocols which define message semantics that are specific to particular functional types of devices. The I<sup>2</sup>C protocol defines the low level transaction over the I2C serial bus, using a single data line (SDA) and a clock line (SCL). The hardware definition for the A.b includes a four wire cable comprised of SDA, SCL and two voltage supply lines. The I<sup>2</sup>C provides for cooperative synchronization of the serial clock, bus arbitration, addressing, byte framing and byte acknowledgement by the receiver. The I2C is a multimaster protocol. and in ACCESS.bus subset the transmitter is always a master. The I2C allows 128 7 bit addresses, of which 125 may be used in A.b for peripheral microcontrollers. The I2C protocol burden is typically handled by microcontrollers both at the peripherals and at the host. The Base Protocol establishes the A.b characteristics including message envelope format, predefined control and status messages, configuration process and the special role of the host. The host acts as a manager of the bus, and all data communication is between the host and peripheral devices—there are no message transactions between peripherals. In A.b, masters are exclusively senders and slaves are exclusively receivers. The host and the attached devices assume master or slave roles at the proper time. An A.b message is an I<sup>2</sup>C bus transaction—a string of bytes sent by a master transmitter where each byte is acknowledged by the slave receiver, and the whole transaction is delimited by Start and Stop conditions. The minimum length of a message is four bytes, and the format definition includes specific locations for source address, destination address, message length and checksum. A protocol flag bit specifies whether the message is a device data stream or a control/status message. The configuration process is designed to permit auto addressing and hot-plugging of devices. This process detects what devices are present on the bus, assigns unique bus addresses to the attached devices and connects them with the appropriate bus drivers. The configuration process is supported by eight pre-defined control/status AN445 messages. In any A.b system the host address is always the same (50H). When the system is powered up all the peripherals perform self testing, assume a default address (6EH) and send to the host an Attention message announcing their presence. The host sends to each device an identification request message, to which the devices respond with a unique 28 byte ID string. Having received the ID string, the host assigns to each device a unique address. In the case of hot-plugging, the peripheral device and the host will interact in a manner similar to the message exchange during system power up. In the last phase of the configuration process the host interrogates each device for its "capabilities string"—which describes the functional characteristics and the potential operating modes of the A.b peripheral. Capabilities information allows the software to recognize and use bus devices without additional knowledge about their specific implementation. Using the capabilities information enables writing 'generic' software drivers that can support a range of similar devices, providing some level of device independence and modularity. The capabilities information is transferred to the host as a readable ASCII string with a simple syntax. A.b application protocols are specific to particular types of devices. The initial A.b specifications define Application protocols for three classes of peripherals: keyboards, locators and text devices. Each class is relatively broadly defined, leaving room for a variety of different devices. When drivers in the operating software of the host fully support a certain class, all devices conforming to the relevant Application Protocol will be supported, without any need for a special software driver. The Application protocols already defined can support many standard desktop peripherals. The Keyboards protocol supports up to 255 keys. Locator devices can have up to 15 degrees of freedom and up to 16 binary keys or buttons. This can cover devices like mouse, tablet, trackball, 'virtual reality' pointing gloves, dial boxes and function key boxes. The Text Device protocol supports devices that transmit or receive messages consisting of strings of characters in some fixed character set. The simple protocol allows high level flow control, and is appropriate for devices like barcode readers, printers and magnetic card readers. Each of the Application Protocols has its own set of control/status messages in addition to the predefined messages of the Base Protocol. #### I<sup>2</sup>C Protocol Handling The I<sup>2</sup>C hardware interface on the 8XC751 operates on a bit by bit basis, and the full I2C protocol is supported by a combination of hardware and firmware. This arrangement results in a very compact hardware circuitry necessary for a low cost integrated circuit. The hardware activates and monitors the SDA and SCL lines, performs the necessary arbitration and framing errors checks, and takes care of clock stretching and synchronization. The hardware is synchronized to the software either through polled loops or interrupts. An I<sup>2</sup>C interrupt is usually requested (if enabled) when a rising edge of SCL indicates a new data on the bus (DRDY), or when a special condition occurs: a frame Start (STR), Stop (STP) or an arbitration loss (ARL). The interrupt is caused by the ATN flag, which is turned on by any of the interrupt inducing conditions. The ATN flag can be polled in a software loop as well. The example code handles the I<sup>2</sup>C protocol from an interrupt service routine (ISR). Typically, processing of a frame will be started with an interrupt (at the I2CINT label). If the bus operates at full speed, firmware processing inside a frame will be synchronized to the hardware bit by bit by a polling loop. The firmware polls the ATN flag in a loop limited to about 50 us (WaitATN) whenever it expects something to happen on the bus. If nothing happens during this period of time, the ISR is exited with the I<sup>2</sup>C interrupt re-enabled. When some bus event will occur later on, processing will resume with a new interrupt. Processing of bus events monitored by the polling loop is identical to processing events detected by an interrupt. The context from which the mouse was sending or receiving a message is maintained between events (ATN flag activations), and is not lost when exiting the interrupt service routine. The I2Ccxt byte stores the event that is expected, like waiting to send a bit or waiting for an acknowledge. Other I2C context elements are the data byte currently in the send or receive process (I2CDat), a bit counter (BitCnt) keeping track of the location within that data byte and a message byte counter (ByteCnt). In addition to the parameters that maintain the context of the very 'generic' |<sup>2</sup>C communications, the code maintains some additional context elements that are relevant to the higher level A.b protocol. These are the computed checksum (Check), the type of message or command being received (RcvType), the type of message being sent or pending (SndType) and a flag indicating that a Position Report transmission is pending (SendRpt). The Interrupt service routine proceeds in handling the low level details of the I<sup>2</sup>C protocol as a Slave receiver or a Master transmitter. The routines for Slave or Master processing are separate, and the jump to either one from DISPAT in I2CDONE routine is determined by the MST bit of the I2CON hardware register. The code examines the flags determining which event caused the ATN and then handles the low level hardware according to the context, performing actions like reading a new bit, acknowledging, sending a bit, issuing a Stop and so forth. When the low level slave receiver code completes reception of a byte, it calls the DORXB routine which deals with the contents of the byte-"application level" routine. Upon return from DORXB there is a call to the Sample subroutines. We effectively sample the quadrature waveforms in between I2C words in order to comply with the requirement for minimum sampling interval. It is interesting to note that code design does not completely separate application code from the I2C low level code—we call Sample from an I2C reception routine (and we do the same in the Master transmission routine). This is because in the 8XC751 the I2C bit processing cannot be done in parallel to other firmware activities and we have to make sure that the application's timing requirements are not being violated. The Master code will start sending a message if the processing routine was entered due to a Start condition. The routine, in fact, fulfills a request that was issued somewhere else in the code. For example, Timer 0 ISR sets the MASTRQ bit of the I2CON register, and sets the SendRpt flag. MASTRQ causes the processor to seize the bus when it is free and issue a Start. The Master processing routine examines the SendRpt flag, and if it is set the routine will start sending a Position Report. In a structure similar to the Slave code bit level details are handled in the MASTER routine. Byte transmissions are set up in the DOTXB routine. #### Processing At The ACCESS.bus Protocol Level A control/status message from the host is identified by the Protocol Flag, the most significant bit of the third message byte. The message body is a code for the command. When such messages are received, they are processed by the DORXCMD routine. Control/Status messages can be of either the Base Protocol or the Application Protocol. In the listing, base protocol codes have the prefix 'L', and application level protocol AN445 commands has the prefix 'App\_' (the definitions are in the include file 'ab.inc'). The Base Protocol commands from the host are I\_Reset, I\_IdReq, I\_ASgnAdr and I\_CapReq. During the configuration process the mouse responds to the host with device to host control/status messages: I\_Attn, I\_IdReply, I\_CApReply and I\_Error. The string for the I IdReply message is defined in GET\_ID. The module revision and vendor name are padded with space characters in order to fit the fixed string length. The last four bytes of the ID string are a device number that can distinguish otherwise like devices with the same firmware. The protocol allows it to be a serial number or a pseudo random number. Our mouse uses a pseudo random number, produced by reading the 16 bit contents of Timer0 that is active since power-up (the number is extended to 32 bits by appending FFFF). The protocol includes 'protection' against the rare event in which two like devices report the same pseudo random number or are mistakenly assigned to the same address. Just prior to sending the first data message to the host, each interactive device transmits a Reset message to its own assigned address (see PosMsg label in the example code). Any other device with the same address will be forced to the power-up default address and will undergo configuration again, as it was hot-plugged onto the bus. The Capabilities String for the I\_CapReply message is defined in GET\_CAP. The string identifies the device as a mouse with specific characteristics: three buttons, two dimensions, relative location reports with 200 dpi resolution etc. The 'prot(locator)' element tells the A.b software driver to use the Locator Device Protocol. The Locator Device Protocol is one of three application protocols already defined for the highest layer of the A.b protocol. This protocol defines a "Locator Event Report" which is used for the Position Reports of the mouse. A Locator Event Report is sent in the format of the device data stream Message defined in the base A.b protocol. The message body includes the current state of the buttons and the location difference from the last report. This data is coded as a sequence of two byte integers. For the mouse which is a two dimensional device, the message data stream length is six bytes, or three integers. The first integer contains the state of 0-15 locator key switches. For the three button mouse, only three of these sixteen bits carry meaningful information. The remaining integers represent the position of the locator dimensions—the contents of the X and Y displacement accumulators. Three control messages specific to the Locator Protocol are processed at DORXCMD. The host initiates a self test by App\_Test. App\_Poll initiates one time transmission of a position report, and App\_Setinterval modifies the default reporting interval controlled by the reload value of Timer0. This note highlights some of the implementation details—the commented listing covers the rest. As one can see, the A.b protocols are relatively simple to program in firmware. The low-level I<sup>2</sup>C implementation on the 8XC751 is somewhat involved, but the same low level routines can be re-used for different devices. The source code files for this program are available for download from the Philips Semiconductors computer bulletin board system. This system is open to all callers, operates 24 hours a day, and can be accessed with modems at 2400, 1200, and 300 baud. The telephone numbers for the BBS are: (800) 451-6644 (in the U.S. only) or (408) 991-2406. Figure 1. Example of Quadrature Encoding Waveforms ``` MS-DOS MACRO ASSEMBLER A51 V4.4 OBJECT MODULE PLACED IN MOUSE.OBJ ASSEMBLER INVOKED BY: A51 MOUSE.A51 ``` ``` LINE 1 2 ; Module: mouse.a51 3 ; Firmware design and code for I2C desktop bus Mouse 5 Environment: 83C751 Assembler 6 Author: Robert Clemens 10-Jul-1990 (I2C I/O adapted from P.Sichel's "Keyboard" code) 8 Revision: 6-Mar-1991 9 10 31-Jan-1991 PAS Add numerous keyboard fixes. 11 Streamline input sample and I2C code. ; 12 Separate HW dependent constants. 13 Fix RxEnable after bus time out. ٠, 14 15 06-Feb-1991 PAS Rev X0.6 16 Fix sample timer initialization, use 14ms as default. 17 Fix length checking to allow commands with 18 more parameters than required. 19 Implement Set Interval command. 20 Handle LLLLL=0 to mean 32. Fix ARL during self-addressed reset message. Fix to handle DRDY and ARL together. Re-order mouse buttons as MRL, update Capabilities. Do not allow other interrupts during TimerI svc. 2.4 25 Document sampling requirements. 2.6 Document hardware details. 27 Add check to skip waiting after DNRXB. 2.8 Misc clean-up in: BeMast, Assign, ... 29 Use include files for 751 registers and ODB msgs. 30 6-Mar-1991 PAS Rev X0.7 32 Fix MN8Bit to check ARL before clearing DRDY. Separate SendRpt flag from movement detected (Movement) so only TimerO will initiate motion reports. 35 Don't send Position report to def_addr even if polled. 36 Report InputError for invalid checksum, 37 unrecognized command code, or illegal parameter 38 value. Do not complain about parameters beyond 39 those anticipated. 40 Sample quadrature inputs between I2C bytes 41 to insure accurate tracking. 42 43 13-Mar-1991 PAS Fix DoStp4 to borrow Rx code and become IDLE rcv. 45 26-Mar-1991 PAS Rex X0.8 46 Update to use 4-byte device number. 47 Get new device number only after Reset. 48 49 8-Apr-1991 PAS Add error checking to CapReg. 50 51 9-Jul-1991 PAS Add protocol_revision as part of module revision. 52 29-Jul-1991 PAS Protocol_revision in 1-byte, fix ARL and MASTER bug. 53 Ignore unrecognized commands. Add I_MsgCheck. 11-Sep-1991 PAS Rev X1.2. Identify button positions as 1,2,3. ``` ``` LOC OBJ LINE SOURCE 57 Use new ab.inc file. Change I_MsgCheck to 58 I_Error and do not overwrite pending SndType. 59 Retry message after Negative Ack (NACnt). 60 7-Oct-1991 PAS Rev X1.3. Fix spurious large count problem. Fix STOP detected while MASTER without ARL. 63 64 25-Oct-1991 PAS Rev X1.4. Improve TimerI handler to avoid 65 lockup when MASTRQ with SCL low. 66 67 4-Nov-1991 PAS V1.0 release for Boston mfg. 68 22-Dec-1991 PAS V1.1 align data with tx bit that lost arbitration 69 70 74 75 76 $ TITLE (Digital ACCESS.bus Mouse, V1.1) 77 $ DATE (12/22/91) 78 S DEBUG 79 $ NOMOD51 ;83C751 is not model 51 80 ;Define SFRs explicitly 81 82 83 ; Symbolic addresses and masks $ INCLUDE( /dskbus/include/arch/reg751.inc ) =1 ************************** =1 ; Module: /dskbus/include/arch/reg751.inc =1 89 ; 83c751 SFR declarations =1 90 Environment: 83C751 Assembler =1 91 =1 95 Date Revision Perpetrator 96 =1 =1 97 30-Jan-91 X0.1 Mark Shepard =1 98 Created (from previous keyboard module) =1 99 =1 100 =1 101 =1 102 $EJ 103 =1 104 =1 105 ; Interrupt Enable Register 8A00 = 1 106 IE EQU 0A8h 0000 =1 107 EX0 EQU 0 ;External interrupt 0 0001 =1 108 ET0 EQU ;Timer0 interrupt 0002 =1 109 EX1 EQU 2 ;External interrupt 1 0003 =1 110 ET1 EQU 3 ;TimerI interrupt 0004 =1 111 EI2 FOU 4 ;I2C interrupt 0007 =1 112 EOU ;All interrupt enable/disable bit =1 113 =1 114 ; I2C Control Register 0098 =1 115 12CON EQU 098h =1 116 ; Input (read) is bit #s for JB etc... 0007 =1 117 7 RDAT EQU :receive data 0006 =1 118 ATN EQU 6 ;attention 0005 =1 119 DRDY EOU - 5 ;data ready 0004 =1 120 ARL EQU 4 ;arbitration loss 0003 =1 121 STR EQU 3 ;start =1 . 122 STP EQU ;stop ``` AN445 | LOC OBJ | | LINE | SOURCE | | | |---------|----------|------|------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0001 | =1 | 123 | MST EQU | 1.1 1.1 1.1 1.1 1.1 1.1 1.1 1.1 1.1 1.1 | ;master | | 0001 | =1 | 124 | | te) is binary values | | | 0080 | =1 | 125 | CXA EQU | 80h | ;clear xmit active | | 0040 | =1 | 126 | IDLE EQU | 40h | ;set to idle slave | | 0020 | =1 | 127 | CDR EQU | 20h | | | | =1 | | | | clear data ready | | 0010 | | 128 | CARL EQU | 10h | clear arbitration loss | | 0008 | =1 | 129 | CSTR EQU | 08h | clear start | | 0004 | =1 | 130 | CSTP EQU | 04h | ;clear stop | | 0002 | =1 | 131 | XSTR EQU | 02h | transmit start | | 0001 | =1 | 132 | XSTP EQU | 01h | ;transmit stop | | | =1 | 133 | | | | | 0000 | =1 | 134 | ; I2C Data Reg | | | | 0099 | =1 | 135 | I2DAT EQU | 099h | | | 0080 | =1 | 136 | XDAT EQU | 80h | ;transmit data | | | =1 | 137 | | | | | | =1 | 138 | | ration Register | | | 00D8 | =1 | 139 | I2CFG EQU | 0D8h | | | 0800 | =1 | 140 | SLAVEN EQU | 80h | ;enable slave mode | | 0007 | =1 | 141 | SLAVENB EQU | 7 | | | 0040 | =1 | 142 | MASTRQ EQU | 40h | ;master request | | 0006 | =1 | 143 | MASTRQB EQU | 6 | | | 0020 | =1 | 144 | CLRTI EQU | 20h | ;clear timerI | | 0005 | =1 | 145 | CLRTIB EQU | 5 | | | 0010 | =1 | 146 | TIRUN EQU | 10h | ;timerI run | | 0004 | =1 | 147 | TIRUNB EQU | 4 | | | | =1 | 148 | | | | | 0088 | =1 | 149 | TCON EQU | 088h | ;Timer Control | | | =1 | 150 | | | | | | =1 | 151 | ; 83C751 SFRs | | | | 080 | =1 | 152 | PO EQU | 080h | | | 0080 | =1 | 153 | SCL BIT | P0.0 | | | 0081 | =1 | 154 | SDA BIT | P0.1 | | | 0081 | =1 | 155 | SP EQU | 081h | | | 0082 | =1 | 156 | DPL EQU | 082h | | | 0083 | =1 | 157 | DPH EQU | 083h | | | 008A | =1 | 158 | TL EQU | 08Ah | ;Timer Lo | | 008B | =1 | 159 | RTL EQU | 08Bh | ;Reload TL | | 008C | =1 | 160 | TH EQU | 08Ch | ;Timer Hi | | 008D | =1 | 161 | | 08Dh | | | 0090 | =1 | 162 | | | ;Reload TH | | | | | , <del>-</del> , | 090h | | | 00B0 | =1 | 163 | P3 EQU | 0B0h | | | 00D0 | =1 | 164 | PSW EQU | 0D0h | | | 00E0 | =1 | 165 | ACC EQU | 0E0h | | | 00F0 | =1 | 166 | B EQU | 0F0h | | | | =1 | 167 | | | | | | =1 | 168 | ,******* | *** End of include f | ile | | | | 169 | | | | | | | 170 | | skbus/include/ab.inc | | | | =1 | 171 | ;******** | ******module ab.inc | ******** | | | =1 | 172 | ; | | | | | =1 | 173 | ; Ab Base Prot | tocol definitions | | | | =1 | 174 | ; Environmen | nt: 83C751 Assemble | | | | =1 | 175 | ; | | | | | =1 | 179 | ; Date | Revision P | erpetrator | | | =1 | 180 | <b>7</b> | | The state of s | | | | | | M | and Observed | | | =1 | 181 | ; 04-Sep-91 | M | ark Shepard | | | =1<br>=1 | 182 | | | | | | | | ; Change | ed I_MsgCheck to I_E | ark Snepard<br>error, kept I_MsgCheck for backpatibility<br>correspond to I_Error). | August 1992 510 ``` LOC OBJ LINE SOURCE =1 185 =1 186 04-Aug-91 Mark Shepard =1 187 Renamed to generic "ab.inc" Added defines for header structure (mainly for documentation purposes). =1 188 =1 189 Added defines for bus signal codes (RESET, HALT, ATTN, etc.) =1 190 =1 191 22-May-91 X0.2 Peter Sichel Added Vendor command codes, and I_MsgCheck. =1 192 =1 193 ; =1 194 30-Jan-91 X0.1 ٠; Mark Shepard =1 195 Created from ODB base protocol spec, X0.7. 196 =1 197 =1 198 =1 SEJ =1 199 Desktop bus command codes for all Interface-part and Application-part =1 200 =1 201 commands in the Base Protocol spec. =1 202 203 =1 ; Naming Convention - =1 204 Interface-Part codes are prefixed with "I_", =1 Application-Part with "App_". Codes specific to a particular =1 206 sub-protocol (e.g. Keyboard Protocol) could be prefixed with =1 207 "Key_", "Kb_", or "Kbp_". ; =1 208 =1 209 Definitions for sub-protocols should go in separate include files. =1 210 (keyp.inc, locp.inc, textp.inc, etc.). =1 211 0000 =1 212 I_NoMsg EQU 000h ; special value, means not a valid message =1 213 00F0 =1 214 I_Reset 0f0h EOU ; reset device 00F1 =1 215 I IdRea 0f1h EOU ; Identify request 00F2 =1 216 I_AsgnAdr EOU 0f2h ; assign address 00F3 =1 217 I_CapReq EQU 0f3h ; capabilities (fragment) request =1 218 00E0 =1 219 EQU I Attn 0e0h ; power-on/reset attention 00E1 =1 220 I_IdReply EQU 0e1h ; identify reply 00E3 =1 221 I_CapReply EOU 0e3h ; capabilities (fragment) reply 00E4 =1 222 I_Error EQU 0e4h ; (the future) interface/bus std error report 00E4 =1 223 I_MsgCheck EQU 0e4h ; *** obsolete, don't use in new code *** =1 224 00C0 =1 225 I_Vendor0 EOU 0c0h ; vendor reserved command 00C1 =1 226 I_Vendor1 EOU 0c1h ; vendor reserved command 00C2 =1 227 I_Vendor2 EQU 0c2h ; vendor reserved command 00C3 =1 228 I_Vendor3 EQU 0c3h ; vendor reserved command =1 229 00A0 230 =1 App_Sig EQU 0a0h ; hardware signal 00A1 =1 231 App_TestReply EQU 0a1h ; test reply (for a specific application-part) =1 232 00B1 =1 233 App_Test EQU 0b1h ; self-test result request 00B4 =1 234 App_Error EQU 0b4h ; (the future) std application error report =1 235 =1 236 =1 237 ; Well-known I2C addresses used by desktop bus peers =1 238 =1 239 ; I2C Address Allocation =1 240 ; row column =1 241 ; A6, A5, A4 / A3, A2, A1, A0 R/W=0 (write) =1 242 ; Host: 2/8 50h =1 243 ; Devices: 2/9-2/15, 3/0-3/7 52-6Eh (even numbers only) ``` AN445 ``` LINE SOURCE LOC OBJ 244 =1 ; Device default: 3/7 6Eh =1 245 0050 =1 246 Adr_Host EQU 050h ; standard Host address 006E =1 247 Adr_Default EOU 06eh ; default (pwr-up) address for peripherals =1 248 ,********* =1 249 250 ; Bus-Signal codes defined at the Base Protocol level =1 =1 251 0001 =1 252 Sig_Reset EOU 1 ; hardware reset! 0002 Sig_Halt 2 =1 253 EQU ; debugging interrupt 0003 =1 254 Sig_Attn EQU 3 ; general-purpose interrupt from User =1 255 =1 256 =1 257 Defines related to message structure 258 =1 ; Declarations prefixed with "AbWire_" refer to Ab objects, fields, etc. =1 260 as transmitted across the i2c "wire" (as opposed to the "optimized frame =1 261 format used between the host and 83c751 host-ctrlr). =1 262 263 =1 0003 =1 264 AbWire_HdrSiz EOU 3 ; Ab Header Size on the wire: dst + src + PLen 007F =1 265 AbWire_LenMask EQU 7fh ; Ab mask for length field 007F =1 266 AbWire_MaxLen EQU 127 ; Ab maximum data bytes in message =1 267 268 ;****** End of include file 269 270 271 SEJ ; *********************** 272 273 ; * Hardware/timing-dependent constants * ; ******************************* 274 275 276 ;CT EQU 02h ;CT1, CT0 fmax = 16.8 MHz 277 ;CT EOU 01h ;CT1, CT0 fmax = 14.25 MHz 278 ;CT 00h ;CT1, CT0 fmax = 11.7 MHz 0003 279 CT EQU 03h ;CT1, CT0 fmax = 9.14 MHz 280 009A 281 IntEnab EOU 09Ah ;enable EA+EI2+ET1+ET0. 0010 282 INIT_TCON 010h EQU ;TimerO init for internal operation. 283 00DB 284 DEF_RTH EOU 0DBh ; Sampling interval (14ms with 8 MHz clock). 008B 285 DEF_RTL EOU 08Bh ; Used as default TimerO reload value. 0002 286 MSECH EQU 002h ; Timer offset for 1 ms with 8 MHz clock. 009A 287 MSECL EQU 09Ah ; 029Ah=666 * 3/2 mms/tick = 1000 ticks = 1ms. 288 0008 289 DelayATN EQU ;about 50µS (wait for I2C activity) 290 0010 291 CapFragLen EOU 16 ; Capabilities fragment length. 292 293 ; *** Hardware Interface Notes *** 294 ; P3 is used to read the X-Y quadrature inputs. 295 P3.0 = XB 296 P3.1 = XA 297 P3.2 = YA 298 P3.3 = YB 299 300 ; Notice P3.0 is connected to the B side of the X encoder ; while P3.2 is connected to the A side of the Y encoder. 301 ; This is to compensate for the orientation of the inclined cylinders. ``` August 1992 512 AN445 ``` LOC OBJ LINE SOURCE 303 ; Positive X movement causes clockwise rotation of the encoder shaft. 304 ; Positive Y movement causes counter clockwise rotation of the encoder shaft. 305 306 ; P1 is used to read the switch inputs. 307 P1.0 = middle mouse button. P1.1 = left mouse button. 308 309 P1.2 = right mouse button. 310 311 ; 6-Feb-1991 This order of buttons reflects the current PCB layout 312 and is subject to change. 313 $EJ 314 ; Locator messages (device defined) 315 316 ; send types 0003 317 LD_Position EQU 3 ;Device state report 318 319 receive types 00B0 320 LD_Poll EOU 0B0h 0082 321 LD_SetInterval EQU 082h 322 323 324 ; SelfTest errors (0=success) 0000 325 NO ERROR EOU 0001 ROM_ERROR EQU 326 1 0002 327 RAM_ERROR EQU 328 329 330 SEJ 331 332 ; RAM usage * .******** 333 334 ; I2C variables 335 ; Register bank 0 336 ;R0 - command parameter 337 ;R1 - index pointer 0002 338 I2CDat DATA ;The byte being sent or received. 0003 339 BitCnt DATA 03h ;I2C bit counter 340 ByteCnt DATA 04h ;I2C message byte counter 0005 341 ATNCnt. ;ATN Retry counter DATA 05h 0006 342 I2CCxt ;I2C context, the event the CPU is waiting for. DATA 06h 0007 343 07h Temp. DATA ;All purpose temp 344 345 ; Desktop Bus Protocol 0008 346 MyAddr DATA ; I2C address assigned this device. 0009 347 NACnt DATA 09h ; Negative Ack retry counter. 000A 348 RcvType DATA 0Ah ; Message or command type being received. 000B 349 SndType DATA 0Bh ; Message type being sent, or pending. 000C 350 MsgLen DATA 0Ch ;Message length field. 000D Check 351 DATA ODh ; Message checksum. COOR 352 RandH DATA 0Eh ;Random number (2 bytes) 000F 353 RandL 0Fh DATA 354 355 ; Locator report buffer 0010 356 ReportBuf EOU ;Beginning of position report buffer. 0010 357 Switch2 DATA 10h ;Switch data (Buttons 9 to 16) 0011 358 Switch1 DATA 11h ;Switch data (Buttons 1 to 8 ) 0012 359 XBUF2 DATA 12h ;XData transmission buffer (MSB) 0013 360 XBUF1 DATA 13h ;XData transmission buffer (LSB) 0014 361 YBUF2 DATA 14h ;YData transmission buffer (MSB) ``` August 1992 513 | LOC OBJ | LINE | SOURCE | | | | | | |-----------|------|-----------------|---------|------------|---------------------|---------------------|------------| | 0015 | 362 | YBUF1 | DATA | 15h | ;YData transmissi | on buffor (ICB) | | | | 363 | 12011 | DAIA | 1311 | , ibaca ciansmissi | on burrer (LSB) | | | 0016 | 364 | XCOUNT | DATA | 16h | WD-+- | | | | 0017 | 365 | | | | ;XData | | | | | | YCOUNT | DATA | 17h | ;YData | | | | 0018 | 366 | MARKER | EQU | YCOUNT+ | -1 | | | | | 367 | | | | | | | | 0018 | 368 | CapOffset | DATA | 18h | ;Capabilities frag | gment offset | | | 0019 | 369 | CapLen | DATA | 19h | ;Capabilities frag | gment length | | | 001A | 370 | SelfTest | DATA | 1Ah | ;Self Test result | variable location | | | 001B | 371 | RomSum | DATA | 1Bh | ;Hold ROM checksur | n | | | 001C | 372 | SampleClock | DATA | 1Ch | ;Time stamp of las | st sample | | | | 373 | | | | ;3 spare. | | | | | 374 | | | | | | | | | 375 | ; Bit addressa | hle are | a begine a | + 20h | | | | | 376 | ; Location and | | - | | | | | 0020 | 377 | LastXY | | - | | | | | 0020 | | | DATA | 20h | ;Last X/Y Position | | | | | 378 | LastSW | DATA | 21h | ;Last Switch Statu | | | | 0022 | 379 | TranXY | DATA | 22h | ;Port 3 transition | n register (bit add | lressable) | | | 380 | | | | | | | | | 381 | \$EJ | | | | | | | | 382 | ; I2C status a | nd posi | tion scann | ing flags. | | | | 0023 | 383 | Flags | DATA | 23h | | | | | 0018 | 384 | Prot | BIT | Flags.0 | ;1=C/S message; 0= | device data stream | 1. | | 0019 | 385 | SendRpt | BIT | Flags.1 | ;New Position Repo | | | | 001A | 386 | Movement | BIT | Flags.2 | ;Movement detected | | | | 001B | 387 | RxEnable | BIT | Flags.3 | ;I2C receive enabl | | | | 001C | 388 | TxSelfRst | BIT | Flags.4 | | | | | 001D | 389 | KeepID | BIT | _ | | elf-Reset after Ass | ign (0). | | 001E | 390 | NotMyID | | Flags.5 | ;Set means keep sa | me device number. | | | 001E | 391 | <del>-</del> | BIT | Flags.6 | | | | | 0011 | | AA | BIT | Flags.7 | ;Assert Acknowledg | re. | | | 0004 | 392 | | | | | | | | 0024 | 393 | FlagsA | DATA | 24h | | | | | 0020 | 394 | MsgCheck | BIT | FlagsA.0 | ;I2C message check | sum or framing err | or. | | | 395 | | | | | | | | | 396 | | | | ;11 spare | | | | | 397 | | | | | | | | 0030 | 398 | StackBase | DATA | 30h | ;16 byte stack | | | | | 399 | | | | ; need 2 bytes per | subroutine | | | | 400 | | | | ; 4 bytes per inte | | | | | 401 | ;RAM ends at 31 | 7h | | | rrapo (mar 1) | | | | 402 | ; 50 bytes RAM | used. | 64 maximum | | | | | | 403 | | | | | | | | | 404 | | | | | | | | | 405 | \$EJ | | | | | | | | 406 | ********* | | | | | | | | 407 | | | | | | | | | | ; Code begins | | | | | | | 0000 | 408 | ;********* | | | | | | | 0000 | 409 | ORG | 0 - 1 | ;Power | up reset vector. | | | | 0000 01B4 | 410 | AJMP | PwrUp | | | | | | | 411 | | | | | | | | 0003 | 412 | ORG | 003h | ;INTO is | s not used. | | | | 0003 01B4 | 413 | AJMP | PwrUp | | | | | | | 414 | ; | | | | | | | | 415 | ; Use this span | e byte | to hold +1 | ne ROM checksum com | nlement | | | 0005 51 | 416 | DB | 051h | | CIIICONDUM COM | pacific. | | | | 417 | - | | | | | | | 000B | 418 | ORG | 00Bh | ·Timoro | interrupt | | | | 000B 0125 | 419 | AJMP | | | interrupt vector | | | | | 420 | AUMP | Timer( | , 10 DIE | system tick genera | tor | | | | 440 | | | | | | | | LOC | OBJ | LINE | SOURCE | | | | | | | | |--------|--------|------------|-----------------|----------|----------|---------------------|----------|-----------|-----------------|---------| | 0013 | | 421 | | ORG | 013h | ;INT1 is | not use | d. | | | | 0013 | 01B4 | 422 | | AJMP | PwrUp | | | | | | | | | 423 | | | | | | | | | | 001B | | 424 | | ORG | 01Bh | ;TimerI | interrup | t vector | | | | 001B | 014F | 425 | | AJMP | TimerI | ;I2C time | e out ti | mer | | | | | | 426 | | | | | | | | | | 0023 | | 427 | | ORG | 023h | ;I2C int | errupt v | rector | | | | 0023 | 21D8 | 428 | | AJMP | 12CINT | | | | | | | | | 429 | | | | | | | | | | | | 430 | | | | | | | | | | | | 431 | \$EJ | | | | | | | | | | | 432 | ; * * * * * * * | ***** | ****** | ***** | | | | | | | | 433 | ; Timer | Interru | ıpt | | | | | | | | | 434 | | | | erval tim | e out. | | | | | | | 435 | ; * * * * * * * | ***** | ***** | ***** | | | | | | | | 436 | | | | | | | 1 186 | | | 0025 | C0D0 | 437 | Timer0: | | PSW | | | ;Save reg | isters we need | • | | 0027 | C0E0 | 438 | | PUSH | ACC | | | | 14 | | | | E508 | 439 | | MOV | A, MyAdd | | | ;Check fo | r default addre | ess. | | 002B | B46E02 | 440 | | CJNE | | Default,A | ddrOK | | | | | 002E | 801A | 441 | | SJMP | T0Exit | | | | nd Position rep | ports | | | | 442 | | | | | | | ult address. | _ | | 0030 | E590 | 443 | AddrOK: | VOM | A, P1 | | | | ch info from P | T | | | | 444 | | | | | | | on depressed). | | | 0032 | | 445 | | CPL | Α | | | ;Compleme | | n.1 | | | 5407 | 446 | | ANL | A,#0000 | | | | low 3 bits of 1 | | | 0035 | B52105 | 447 | | CJNE | | W,CHNSWI | | movement. | switches did cl | lange | | 0020 | 301A0F | 448<br>449 | | JNB | | it,TOExit | e, check | movement. | | | | | 8009 | 450 | | SJMP | T0Send | IC, IUEXIC | | ·Ves an | send report. | | | . 0036 | 8009 | 451 | | SOME | Tosena | | | , res, go | send report. | | | 003D | F521 | 452 | CHNSWI: | MOV | LastSW, | Α | | :Save Las | tSW for next c | ompare. | | | | 453 | | | | | RLM to I | | PCB is fixed. | • | | 003F | 13 | 454 | | RRC | A | | | | | | | | 92E2 | 455 | | MOV | ACC.2,C | 1 50 546 T | | | | | | | 5407 | 456 | | ANL | A,#0000 | | | | | | | 0044 | F511 | 457 | | MOV | Switch1 | , A | | ;Move to | output buffer. | | | | | 458 | | | | | | | | | | 0046 | D219 | 459 | T0Send: | SETB | SendRpt | <b>.</b> 905 (1994) | | ;Set to s | end Position r | eport. | | 0048 | D2DE | 460 | | SETB | I2CFG.N | MASTRQB | | ;Request | to be master. | | | | | 461 | | | | | | | | | | 004A | D0E0 | 462 | TOExit: | POP | ACC | | | | | | | 004C | D0D0 | 463 | | POP | PSW | | | | | | | 004E | 32 | 464 | | RETI | | | | | | | | | | 465 | | | | | | | | | | | | 466 | \$EJ | | | | | | | | | | | 467 | ;***** | ****** | ***** | ****** | * | | | | | | | 468 | ; Timer | I interr | upt | | | | | | | | | 469 | | 2C bus h | | | | | | | | | | 470 | | | | | | | an active fram | e. | | | | 471 | | | | we can't v | wait for | DRDY. | | | | | | 472 | | o fix it | | | | | | | | | | 473 | ;***** | ****** | ***** | ****** | * | | | | | | | 474 | | | | | | | | | | | C2AF | 475 | TimerI: | | IE.EA | | | e interru | | – | | 0051 | 75D823 | 476 | | VOM | I2CFG, | #CLRTI+CT | | | and turn off T | | | 0054 | 7500DQ | 477 | | WOTT | T20017 | #GV3 . G3 D7 | | | SLAVEN & MASTR | | | | 7598BC | 478 | | VOM | | | | | Clear I2C flag | ъ. | | 0057 | 758130 | 479 | | VOM | SP, #SC | ackBase | ;Reset | or. | | | | LOC | OBJ | LINE | SOURCE | | | | | | | |----------|--------|------|------------|---------|--------------------|-----------------|---------------|--------------------------|-----------------------------------------| | | | 480 | | | | | | | | | | | 481 | ; Attempt | to re | gain control of | the I2C b | nus after a b | ng fault | A 1 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | | 005A | D280 | 482 | FixBus: | SETB | SCL | | | not locking ] | .20 | | 005C | | 483 | | SETB | SDA | , 1110010 | 170 port 18. | not locking i | 120. | | | 308020 | 484 | | JNB | SCL, ResetBus | .Tf COT | 4-1 | | | | | 208113 | 485 | | JB | | | | cannot be fix | | | 0001 | 200113 | 486 | | | SDA, RStop | | | gh, force a s | stop. | | 0064 | 750200 | | | | is low, attempt | | | | | | | 750309 | 487 | | MOV | BitCnt,#9 | | | to clear bus. | | | 0067 | | 488 | ClockBus: | | SCL | ;Force a | n I2C clock. | | | | 0069 | | 489 | | | SDelay | | | | | | | 208109 | 490 | | JB | SDA, RStop | ;Did it | work? | | | | 006E | D280 | 491 | | SETB | SCL | 1.3000 | | | | | 0070 | 11AF | 492 | | ACALL | SDelay | | | | | | 0072 | D503F2 | 493 | | DJNZ | BitCnt,ClockBus | :Repeat | clocks until | SDA clears c | r retry limit | | 0075 | A008 | 494 | | SJMP | ResetBus | | | y this method | | | | | 495 | | | | , | co lin bub b | y chirb mechod | • | | 0077 | C281 | 496 | RStop: | CLR | SDA | ·Tru for | cing a stop s | ningo. | | | 0079 | 11AF | 497 | | | SDelay | | | | | | 007B | | 498 | | SETB | SCL | ; SCL & | SDA are both | nign. | | | 007D | | 499 | | | | | | | | | 007E | | | | | SDelay | | | | | | 0075 | 0201 | 500 | | SETB | SDA | | | | | | 0004 | | 501 | | | | | | | | | 0081 | | 502 | ResetBus: | ;Wait | for bus to clear | r. | | | | | | 3080FD | 503 | | JNB | SCL,\$ | | | | | | | 3081FD | 504 | | JNB | SDA,\$ | | | | | | 0087 | 7401 | 505 | | VOM | A,#1 | | ;Pause for bu | us to stabili | ze. | | 0089 | 11A7 | 506 | | ACALL | LDelay | | | | | | | | 507 | | ;Re-er | nable I2C function | ons. | | | | | 008B ' | 750B00 | 508 | | MOV | SndType, #I_NoMs | | ;Cancel messa | age if any | 100 Mg 200 - | | 008E 1 | 021B | 509 | | SETB | RxEnable | | Enable recei | | | | 0090 | 1194 | 510 | | | InitI2C | | ;Initialize I | | | | 0092 | 2154 | 511 | | | MAIN | | | | | | | | 512 | | AOM | MATIN | | Restart MAIN | <b>(.</b> 211 ).<br>16 0 | | | | | 513 | | | | | | | | | | | 514 | | | | | | | | | 0004 | 75D893 | | | | functions | | | | 4907 | | 0034 | 30033 | 515 | InitI2C: N | | I2CFG, #SLAVEN+T | | Enable I2C | | | | 0007 7 | 750000 | 516 | ; 5 | Set I20 | to be idle rece | eiver & cl | lear all flag | rs. | | | | 7598FC | 517 | MC | | I2CON, #CXA+IDLE- | +CDR+CARL+ | CSTR+CSTP | -9 | | | 009A | | 518 | MC | V | I2CCxt, #RXIDLE | t 4415; | Context idle | receiver | | | 009D 3 | | 519 | AC | CALL | XRETI | · . · · · · · : | Clear pendin | g interrupt | if any. | | 009F | | 520 | MC | V | IE,#IntEnab | | Enable inter | rupts (EA+EI | 2+ET1+ET0) | | 00A2 7 | 410 | 521 | MC | V | A,#16 | 1 | Wait to sync | message fra | me. | | 00A4 1 | 1A7 | 522 | AC | CALL | LDelay | | | | | | 00A6 2 | 22 | 523 | RE | T | | | | | | | | | 524 | | | | | | | | | | | 525 | ; Long Del | av. A/ | 2 milliseconds. | | | | | | 00A7 7 | 'FA6 | 526 | LDelay: MC | | R7,#166 | | | | | | 00A9 I | FFE | 527 | | | R7,\$ | | | | | | 00AB I | | 528 | | | ACC, LDelay | | | | | | 00AE 2 | | 529 | RE | | ricc, incray | | | | | | 201111 2 | _ | 530 | RE | 1 | | | | | | | | | | <b>6</b> 3 | • | | | | | | | 00357 1 | 1.01 | 531 | | | utine (10 machin | e cycles) | • | | | | 00AF 1 | | 532 | | ACALL | SD1 | | | | | | 00B1 C | | 533 | | NOP | | | | | | | 00B2 C | | 534 | | NOP | | | | | | | 00B3 2 | 2 | 535 | | RET | | | | | | | | | 536 | | | | | | | | | | | 537 | \$EJ | | | | | | | | T.00 | ODT | TINE | SOURCE | | | | |------|--------|-------------|------------|----------|-------------------|------------------------------------------| | LOC | OBJ | LINE<br>538 | | ***** | ****** | *** | | | | 539 | • | | ialization starts | | | | | 540 | | | ***** | | | | | 541 | ; Reset | command | branches to here | | | 00B4 | 75086E | 542 | PwrUp: | VOM | MyAddr, #Adr_Defa | ult ;Re-initialize default address. | | 00B7 | E4 | 543 | | CLR | <b>A</b> | | | 00B8 | F5A8 | 544 | | MOV | IE,A | ;Disable interrupts. | | 00BA | 75D803 | 545 | | VOM | I2CFG, #CT | ;Disable I2C | | 00BD | 53D0E7 | 546 | | ANL | PSW,#0E7h | ;Select RB0. | | 00C0 | 758130 | 547 | | MOV | SP,#StackBase | | | | | 548 | | ; Initia | alize I/O pins | | | 00C3 | 758003 | 549 | | MOV | P0,#03h | ;Initialize I2C I/O pins, SCL & SDA high | | 00C6 | 7590FF | 550 | | MOV | P1,#0FFh | ;P1 set for input to read switches. | | 00C9 | 75B0FF | 551 | | MOV | P3,#0FFh | ;P3 set for input to read X-Y. | | | | 552 | | ; Initi | alize Timer0 | | | 00CC | 758DDB | 553 | | MOV | RTH, #DEF_RTH | ;14 ms at 8 MHz | | 00CF | 758B8B | 554 | | MOV | RTL, #DEF_RTL | | | 00D2 | 758810 | 555 | | VOM | TCON, #INIT_TCON | ;Running, internal mode clock/12. | | | | 556 | | | | | | | | 557 | ,***** | **** | | | | | | 558 | ; Perfo | rm ROM T | est (0-7FFh, 2K b | oytes) | | | | 559 | ,***** | **** | | | | 00D5 | 75F000 | 560 | TestROM | : MOV | B,#0 | ;Initialize sum | | 00D8 | 900000 | 561 | | MOV | DPTR,#0000h | ;Set pointer to start of ROM | | 00DB | C3 | 562 | | CLR | С | | | 00DC | E4 | 563 | SumLp: | CLR | A | | | 00DD | | 564 | | MOVC | A, @A+DPTR | ;Get byte from ROM | | | 35F0 | 565 | | ADDC | A,B | ;Add sum | | | F5F0 | 566 | | MOV | B, A | ;Save sum in B | | 00E2 | | 567 | | INC | DPTR | | | | E583 | 568 | | MOV | A, DPH | ;Check if ROM complete | | | B408F4 | 569 | | CJNE | A,#08h,SumLp | | | | 5002 | 570 | | JNC | TestSum | ;Add carry if set | | | 05F0 | 571 | | INC | В | | | | E5F0 | 572 | TestSum | | A,B | | | | 6007 | 573 | | JZ | TestRAM | ;If zero, ROM is Okay | | | 751A01 | 574 | | MOV | SelfTest, #ROM_EF | | | | F51B | 575 | | MOV | RomSum, A | ;Save bad checksum. | | | 8023 | 576 | | SJMP | BadMem1 | | | | | 577 | | | | | | | | 578 | \$EJ | | | | | | | 579 | ,***** | ***** | | | | | | 580 | | | est (0-3Fh, 64 by | vtes) | | | | 581 | | | special function | | | | | 582 | | | are not preserved | | | | | 583 | ,***** | | | | | 00F7 | 78AA | 584 | TestRAM | | RO,#OAAh | ;Test RAM location 0. | | | B8AA1B | 585 | 1000144 | CJNE | R0, #0AAh, BadMem | ,1000 1441 100402011 01 | | | 7855 | 586 | | MOV | R0,#055h | | | | B85516 | 587 | | CJNE | RO, #055h, BadMem | | | | 783F | 588 | | MOV | RO, #3Fh | ;Init R0 to top of RAM. | | | 74AA | 589 | | MOV | A,#0AAh | ;Test alternate bits. | | | 86F0 | 590 | ChkRAM: | | B, @RO | ;Save previous contents. | | 0107 | | 591 | CILKIONI . | MOV | GRO, A | , said provides concents. | | | B6AA0C | 592 | | CJNE | @RO,#OAAh,BadMer | m | | 010B | | 593 | | RL | A | ;Test other bits. | | 0100 | | 594 | | MOV | @RO,A | , <u>1919 Odnor Stop</u> , | | | B65507 | 595 | | CJNE | @RO,#055h,BadMer | m | | 0110 | | 596 | | RL | A | | | 0 | | 200 | | | | | AN445 | LOC OBJ | LINE | SOURCE | | | | | | | |------------------------|------|--------------------|----------|--------------------|-----------|--------------|------------------|--------------| | 0111 A6F0 | 597 | | MOV | @RO,B | ;Restor | e contents. | | | | 0113 D8F0 | 598 | | DJNZ | RO, ChkRAM | | | | | | 0115 8005 | 599 | | SJMP | MemOK | | | | | | 0117 751A02 | 600 | BadMem: | | SelfTest, #RAM_E | RROR | | | | | | 601 | | - 777 | | | | | | | | 602 | Repor | t had m | emory. Since a m | emory nr | oblem was d | etected the | | | | 603 | | | ransmit code may | | | | | | | 604 | | | lem and use it an | | _ | | | | | 605 | | | Could add special | | _ | so much | | | 011A 8005 | 606 | , we ca<br>BadMem1 | | InitRAM | code ne | re. | | | | 011K 0003 | 607 | Бастепі | : SUMP | INICKAM | | | | | | 011C 751A00 | | | | a 16 | | | | | | 011F 8000 | 608 | MemOK: | | SelfTest,#0 | | | | | | 011F 8000 | 609 | | SJMP | InitRAM | | | | | | | 610 | | | | | | | | | | 611 | | | | | | | | | | 612 | \$EJ | | | | | | | | | 613 | ;***** | **** | | | | | | | | 614 | | lize RA | M | | | | | | | 615 | ; * * * * * | **** | | | | | | | 0121 E4 | 616 | InitRAM | :CLR | A | | ;Init Acc | to Zero | | | 0122 F50A | 617 | | MOV | RcvType, A | | ;Clr RcvTy | ре | | | 0124 F50B | 618 | | MOV | SndType, A | | ;Clr SndTy | oe<br>oe | | | 0126 7910 | 619 | | MOV | R1, #ReportBuf | | | ort buffer & com | mpare vars | | 0128 F7 | 620 | ClrBuf: | MOV | @R1,A | | ;Clear loca | | | | 0129 09 | 621 | | INC | R1 | | ;Go to next | | | | 012A B918FB | 622 | | CJNE | R1,#Marker,ClrB | nf | ;Check for | | | | 012D F523 | 623 | | MOV | Flags, A | | ;Init Flags | | | | 012F F521 | 624 | | MOV | LastSW, A | | | switch image. | | | 0131 750905 | 625 | | MOV | NACnt,#5 | | | _ | | | 0101 /00000 | 626 | | 1100 | NACIIC, #J | | ; Negative A | Ack retry count. | | | | 627 | ;Init L | 2 a t VV | | | | | | | 0134 E5B0 | 628 | , IIIIC D | MOV | 3 77 | | | | | | 0134 E3B0<br>0136 540F | | | | A, P3 | | | quad inputs to i | .nit LastXY. | | 0138 F520 | 629 | | ANL | A,#00Fh | | ;Low 4 bits | - | | | 0130 F320 | 630 | | VOM | LastXY,A | | ;Init Last | ζΥ | | | | 631 | | | | | | | | | | 632 | ; * * * * * | | | | | | | | | 633 | | | nsmit self test re | eport | | | | | | 634 | ; **** | **** | | | | | | | 013A C21B | 635 | | CLR | RxEnable | | ;Disable re | eceiving. | | | 013C 1194 | 636 | SetUp: | ACALL | InitI2C | | | | | | | 637 | | | | | | | | | 013E 750601 | 638 | Report: | VOM | I2CCxt, #RXIDLE | | ;Set contex | t idle receiver | ; *RC* | | 0141 750BE0 | 639 | | MOV | SndType,#I_Attn | | | | | | 0144 D2DE | 640 | | SETB | I2CFG.MASTRQB | | ;Request to | be master. | | | 0146 20DEFD | 641 | | JB | I2CFG.MASTRQB,\$ | | ;Wait for m | nessage sent. | ;*PAS* | | 0149 E51A | 642 | | MOV | A, SelfTest | | | an Tarangan (an | · | | 014B 6005 | 643 | Kilomatan Santa | JZ | RepDn | | ;Go if Self | test OK | | | | 644 | | | | | | | | | | 645 | | ;Selfte | est failed. | | | | | | | 646 | | | 2nd report and try | z to sta | rt anyway | | | | 014D 751A00 | 647 | | MOV . | SelfTest, #NO_ER | | c anyway. | | | | 0150 80EC | 648 | | SJMP | Report | CIN STATE | | | | | , , | 649 | | SOME | Vebotr | | | | | | 0152 D21B | 650 | RepDn: | SETB | RxEnable | | | | | | 3132 0210 | 651 | vebou: | SEID | vvriiante | | | ceiver and | | | | 652 | | | | | ; rail thro | ough to MAIN. | | | | 653 | Ċ D T | | | | | | | | | 023 | \$EJ | | | | | | | August 1992 AN445 Application note | LOC OBJ | LINE SOURCE | | | | |-------------|---------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | 200 020 | 654 ;****** | ****** | ********** | ****** | | | 655 ; Main Rou | tine | | | | | 656 ; | | | | | | | -Y quadrature inputs a | and compute mouse movement. | | | | · · · · · · | | 3% 0-10 inches per second. | | | | | | i means up to 2000 input change | es/second | | | | | te is 4000/sec or sample every | | | | · · · · · · · · · · · · · · · · · · · | only two character time | | 230µ3. | | | | | ple between every I2C character | <u>,</u> | | | 663 ; | accuracy, should same | ore between every ize character | • | | | · | iming with 8 MHz cryst | 1. | | | | | | | | | | | | | | | | | transition: 25-31 cy | | | | | | Y transition: 42-46 cy | /cles 63-69μs | | | | 668 ; | | | | | | 669 ;****** | | ***** | ***** | | 04.54 | 670 | | | | | 0154 | 671 MAIN: | | | | | 0154 E58A | 672 MO | | ;Read timer to wait at least | | | 0156 951C | | BB A, SampleClock | ; 64 cycles (96 $\mu$ sec) between | samples. | | 0158 30E6F9 | 674 JN | B ACC.6, MAIN | | | | | 675 ;T | ake a sample | | | | | 676 ;C | LR IE.EA | ;Protect sample code from inte | errupts. | | 015B 858A1C | 677 MO | V SampleClock,TL | | | | 015E 3162 | 678 AC | ALL Sample | ;Sample X-Y quadrature inputs | | | | 679 ; S | ETB IE.EA | | | | 0160 80F2 | 680 SJ | MP MAIN | | | | | 681 | | | | | | 682 ; Sample X | K-Y quadrature inputs a | and update X-Y counters. | | | | 683 ; b3-b0 | = YB YA XB XA. | | | | | 684 ; | | | | | | 685 ; Channe | 1 A: 0 1 1 0 0 1 1 0 | 0 0>positive movement | | | | 686 ; Channe | el B: 0011001 | 1 0 <negative movement<="" td=""><td></td></negative> | | | | 687 | | | | | | 688 ; A and | C are not preserved. | | | | | 689 | | | | | 0162 E5B0 | 690 Sample: MO | OV A,P3 | ;Read X & Y position detectors | s. | | 0164 540F | 691 AN | L A,#00001111B | ;We only need the low 4 bits | | | 0166 B52001 | 692 CJ | NE A, LastXY, TRAN | ;Compare to last image. | | | 0169 22 | 693 RE | <b>T</b> (philip | ; If no change, return. | | | | 694 | | | | | 016A 852022 | 695 TRAN: MC | V TranXY, LastXY | ;Set up to calculate XY trans | ition. | | 016D F520 | 696 MC | | ;Save new P3 image. | | | 016F 6222 | 697 XF | • | ;Mark transition bits (1=change | ged). | | | 698 | | | | | 0171 20100A | 699 XPULSE: JE | TranXY.0,XA | ;Branch on bit transitions. | | | 0174 201113 | 700 JE | | | | | 0177 201232 | 701 YPULSE: JE | • | | | | 017A 20133B | 702 JE | · · | | | | 017D 22 | 703 RE | | | | | | 704 | <del></del> | | | | | | Decode direction from ( | miadrature | | | | | Change in XA | quadrature. | | | 017E E520 | 707 XA: MC | | and the state of t | | | 0180 5403 | 707 AA: MC | · · · · · · · · · · · · · · · · · · · | ·Cot V' V | | | 0182 6010 | 709 JZ | | ;Get X' X<br>;If 00, backward | | | 0184 6403 | 710 XF | | ,II JU, DACKWAIG | | | 0186 600C | 710 XF | | ;If 11, backward | | | 0188 8016 | | MP XINC | ;01 or 10, forward. | | | 3200 0010 | ,12 50 | ALIVO | , or or to, torward. | | | LOC | OBJ | LINE | SOURCE | | | | | | |-------|----------------|------------|-----------------|-------------|-----------------|--------------|----------------------|-------| | | | 713 | | ;Change | in XB | | | | | 018A | E520 | 714 | XB: | MOV | A,LastXY | | | | | 018C | 5403 | 715 | | ANL | A,#00000011B | ;Get X' X | K | | | 018E | 6010 | 716 | | JZ | XINC | ;If 00, 1 | forward | | | 0190 | 6403 | 717 | | XRL | A,#00000011B | | | | | 0192 | 600C | 718 | | JZ | XINC | ;If 11, i | forward | | | | | 719 | | ;01 or | 10, backward, i | fall through | n to decrement | | | | | 720 | | | | | | | | 0194 | 7480 | 721 | XDEC: | MOV | A,#080h | | decrement if | | | | 6516 | 722 | | XRL | A, XCOUNT | ; count a | already at minimum - | 127. | | 0198 | | 723 | | JZ | XDEC2 | | | | | 019A | 1516 | 724 | | DEC | XCOUNT | | | | | | D21A | 725 | | SETB | Movement | | sition has changed. | | | 019E | 80D7 | 726 | XDEC2: | SJMP | YPULSE | ;Check fo | or possible Y pulse. | | | | | 727 | | | | | | | | 01A0 | | | XINC: | MOV | A,#07Fh | ;Do not i | increment if | | | 01A2 | | 729 | | XRL | A, XCOUNT | ; count a | already at maximum 1 | 27. | | 01A4 | | 730 | | JZ | XINC2 | | | | | 01A6 | | 731 | | INC | XCOUNT | | | | | | D21A | 732 | | SETB | Movement | | sition has changed. | | | 01AA | 80CB | 733 | XINC2: | SJMP | YPULSE | ;Check fo | or possible Y pulse. | | | | | 734 | | | | | | | | | | 735 | | ;Change | | | | | | 01AC | | 736 | YA: | VOM | A, LastXY | | | | | | 540C | 737 | | ANL | A,#00001100B | ;Get Y' Y | | | | 01B0 | | 738 | | JZ | YDEC | ;If 00, h | packward | | | | 640C | 739 | | XRL | A,#00001100B | 14 | | | | | 600C | 740 | | JZ | YDEC | ;If 11, k | | | | 01B6 | 8015 | 741 | | SJMP | YINC | ;01 or 10 | ), forward. | | | 0150 | <b>TF00</b> | 742 | | ;Change | | | | | | 01B8 | | 743 | YB: | MOV | A, LastXY | | Augustus (1997) | | | | 540C | 744 | | ANL | A,#00001100B | ;Get Y' Y | | | | 01BC | | 745 | | JZ | YINC | ;If 00, f | forward | | | | 640C | 746 | | XRL | A,#00001100B | -5 44 | | | | 0100 | 600B | 747 | | JZ | YINC | ;If 11, f | | | | | | 748 | | ; u1 or . | 10, backward, 1 | tall through | n to decrement. | | | 01.00 | 7400 | 749 | WDDG. | ***** | | _ | | | | 01C2 | | 750 | YDEC: | MOV | A,#080h | | decrement if | 405 | | 01C4 | | 751 | | XRL | A, YCOUNT | ; count a | already at minimum - | 127. | | 0106 | | 752<br>753 | | JZ | YDEC2 | | | | | 0108 | D21A | 754 | | DEC<br>SETB | YCOUNT | . 37 - 4 | | | | | | | VDEC2. | | Movement | , Note pos | sition has changed. | | | 01CC | 20 | 755<br>756 | YDEC2: | RET | | | | | | 0100 | 747F | 757 | YINC: | MOV | A,#07Fh | ·Do not | increment if | | | 01CF | | 758 | 11110. | XRL | A, YCOUNT | | already at maximum 1 | 27 | | 01D1 | | 759 | | JZ | YINC2 | , count a | illeady at maximum i | 21. | | 01D3 | | 760 | | INC | YCOUNT | | | | | | D21A | 761 | | SETB | Movement | ·Note nos | sition has changed. | | | 01D7 | | 762 | YINC2: | RET | 110 V CINCIIC | , Note pos | sicion has changed. | | | | and the second | 763 | | | | | | | | | | 764 | \$EJ | | The three lines | | | | | | | 765 | , | | ; I2C message | processing | contexts: | | | 000 | 01 | 766 | RXIDLE | EQU | 1 | | eceiver waiting for | start | | 000 | | 767 | RXBIT | EQU | 2 | | ng to receive a bit. | | | 000 | | 768 | RXACK | EQU | 3 | | ng for ACK to comple | | | | | 769 | | ~~ | | , | | | | 000 | 04 | 770 | TXBIT | EQU | 4 | ;Waitir | ng to send a bit. | | | 000 | | 771 | TXREAD | - | 5 | | ng to read ACK. | | | | | 1. | , <del></del> - | ~ | | , | | | ``` LOC OBJ LINE SOURCE 0006 772 TXACK EOU ; Waiting for ACK. 773 774 775 776 ; I2C Interrupt Reasons 777 Events CPU might be waiting for 778 Receive 779 (1) Start signal detected by idle slave (DRDY) 780 (2) Next bit received (DRDY) 781 (3) Acknowledge has been sent (DRDY) 782 Transmit 783 (4) Bus mastership granted (START and MASTER) 784 (5) Ready to transmit next bit (DRDY) ; 785 (6) Acknowledge received (DRDY) 786 Unsolicited 787 (7) Arbitration loss (ARL) 788 (8) Sender aborted message (STOP) 789 (9) Sender started new message before slave became idle (START) 790 791 ; Only some of these events can occur at any time depending on ; the state of sending or receiving a message. 793 794 ; When the interrupt occurs, the keyboard needs to recover 795 ; the context from which it was sending or receiving a 796 ; message. This context is maintained as follows: 797 798 I2Ccxt I2C context, what event is expected. 799 ; I2CDat The byte being sent or received. 800 BitCnt Where we are in the sending or receiving the byte. 801 ByteCnt Where we are in sending or receiving a message 802 Check Computed checksum. 803 RcvType The message or command type being received. 804 This may determine how successive bytes 805 are to be processed. ٠; 806 SndType Type of message being sent or pending. 807 This will determine how bytes are transmitted. 808 SendRpt Flag indicating CPU is waiting to send a Position 809 report (and requested to become master). 810 811 812 813 SEJ 814 815 ; Enter I2C Interrupt 816 .************ 01D8 C2AC I2CINT: CLR 817 IE.EI2 ; disable the I2C interrupt 01DA 31F3 818 ACALL XRETI ; then re-enable others 01DC C0D0 819 PUSH ; save registers 01DE C0E0 820 PUSH ACC 821 822 ; Dispatch interrupt 01E0 309911 823 DISPAT: JNB I2CON.MST, SLAVE 01E3 41B1 824 AJMP MASTER ;go if we're master 825 826 ; Wait for ATN 01E5 7D08 827 WaitATN: MOV R5, #DelayATN ;Load ATN count (about 50mms) 01E7 209EF6 828 Wait1: JB I2CON.ATN, DISPAT ; If ATN, dispatch next event, 01EA DDFB 829 DJNZ R5, Wait1 ; else loop to try again. 830 ; If not seen after count tries, ``` | LOC | OBJ | LINE | SOURCE | | | | |-------|--------|------|---------|----------|------------------------|-----------------------------------------| | 200 | 020 | 831 | | : retur | n from I2C interrupt. | | | | | 832 | | , recar | . IIom IIc Intellape. | | | | | 833 | · Evit | I2C inte | rrunt | | | | | 834 | | | | nt armunt | | 01.70 | D000 | | | | ters and return from i | nterrupt | | | D0E0 | 835 | I2CRTI: | | ACC | | | | DODO | 836 | | POP | PSW | | | | D2AC | 837 | | SETB | IE.EI2 | ;re-enable I2C interrupt | | 01F2 | 22 | 838 | | RET | | return to interrupted process | | | | 839 | | | | | | 01F3 | 32 | 840 | XRETI: | RETI | | ;used at start of service routine | | | | 841 | | | | | | | | 842 | | | | | | | | 843 | \$EJ | | | | | | | 844 | | ***** | ***** | | | | | 845 | • | RECEIVE | | | | | | 846 | | | | DE-AMMONE DE-TAGGE | | | | | | | R3=BitCnt, R4=ByteCnt, | RS=ATNCHE, R6=12CCXE | | | | 847 | • • | | ***** | | | | | 848 | ; Handl | | | | | | | 849 | ;***** | ***** | ***** | | | 01F4 | 309D5A | 850 | SLAVE: | JNB | I2CON.DRDY,NDRDY | ;Is it DRDY? | | | | 851 | ; - con | text wai | ting for bit | | | 01F7 | BE0235 | 852 | | CJNE | R6, #RXBIT, NRxBit | ;Context waiting for bit? | | 01FA | . EA | 853 | Rx0: | MOV | A,R2 | ;Yes, get data in A | | 01FB | DB21 | 854 | Rx1: | DJNZ | R3,N8Bit | ;8th bit? | | | | 855 | | | | | | | | 856 | | ; Read | 8th bit | | | 01FD | A29F | 857 | | MOV | C, I2CON.RDAT | ;Get 8th bit, don't clear ATN | | 01FF | | 858 | | RLC | A | | | | | | | | | ;Include the 8th bit | | 0200 | | 859 | | VOM | R2,A | ;Put data in R2. | | 0201 | 620D | 860 | | XRL | Check, A | ;XOR it to check | | | | 861 | | | | | | | | 862 | | ;Send A | cknowledge as appropri | ate. | | 0203 | BC0007 | 863 | | CJNE | R4,#0,DoAck1 | ;Address byte? (ByteCnt=0) | | 0206 | B5080E | 864 | | CJNE | A, MyAddr, NotMe | ; Is it my address? | | 0209 | F50D | 865 | | MOV | Check, A | ;Yes, initialize check | | 020B | C21F | 866 | | CLR | AA | ;AA=Flags.7 | | 020D | 852399 | 867 | DoAck1: | MOV | I2DAT, Flags | ;Assert Acknowledge (AA=Flags.7) | | 0210 | 7E03 | 868 | | MOV | R6, #RXACK | ;Set context waiting for ACK | | 0212 | 209D1D | 869 | | JB | I2CON.DRDY,AckCmp | ;Can we skip waiting? | | | 21E5 | 870 | | AJMP | WaitATN | ;Wait for ATN. | | | | 871 | : Not a | ddressed | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | 0217 | 7E01 | 872 | NotMe: | MOV | R6,#RXIDLE | .Cot contout to be idle massing | | | | | Moune: | | | ;Set context to be idle receiver | | | 75987C | 873 | | MOV | I2CON, #CDR+CSTR+CSTP+ | | | 021C | 21EC | 874 | | AJMP | 12CRT1 | ;Resume interrupted activity | | | | 875 | | | | | | | | 876 | | ; Read 1 | bits 1-7 | | | 021E | C2E7 | 877 | N8Bit: | CLR | ACC.7 | | | 0220 | 4599 | 878 | | ORL | A, I2DAT | ;Include the bit, clear ATN. | | 0222 | 23 | 879 | | RL | A | ;Data comes in at MSB. | | 0223 | 209DD5 | 880 | | JB | I2CON.DRDY,Rx1 | ; If DRDY, short cut. | | 0226 | 209DD2 | 881 | | JB | I2CON.DRDY,Rx1 | | | | 209DCF | 882 | | JB | I2CON.DRDY,Rx1 | ;One more try. | | 022C | | 883 | | MOV | R2,A | ; Put data back. | | | 21E5 | 884 | | AJMP | WaitATN | , = = 0 | | 2220 | | 885 | | -10111 | THE CITIES | | | | | 886 | | tout mai | ting for ACK to com-1- | <b>+</b> | | 0225 | Dπ0211 | | | | ting for ACK to comple | | | | BE0311 | 887 | NRxBit: | | R6, #RXACK, NRXACk | ;Context waiting for ACK? | | 0232 | 7598A0 | 888 | AckCmp: | | I2CON, #CDR+CXA | ;ACK complete, clr xmt. | | | | 889 | | ;Proces | s complete byte. | | **AN445** | LOC | OBJ | LINE | SOURCE | | | | |------|--------|------|------------|------------|-------------------------------------------|-------------------------------------| | 0235 | 618F | 890 | | AJMP | DORXB | | | | | 891 | | ; Retu | ırn is AJMP DNRXB. | | | 0237 | 0C | 892 | DNRXB: | INC | R4 | ;Increment ByteCnt. | | | | 893 | | ; ACALL | Sample | | | 0238 | 7E02 | 894 | SetRXB: | VOM | R6,#RXBIT | ;Set context for next byte. | | 023A | 7A00 | 895 | | MOV | R2,#0 | ;Clear receive buffer | | | 7B08 | 896 | | MOV | R3,#8 | ;BitCnt=8 | | | 209DB9 | 897 | | JB | I2CON.DRDY,Rx0 | ;If DRDY, short cut. | | | 21E5 | 898 | | AJMP | WaitATN | ;Wait for ATN | | 0241 | 2123 | 899 | | | Wall Stille | , marc rot min | | | | 900 | | tort id | ile slave | | | 0242 | DE010D | | | | | 0 | | | BE010B | 901 | NRxAck: | | R6, #RXIDLE, NRxIdle | ;Context idle slave? | | 0246 | 301BCE | 902 | | JNB | RxEnable, NotMe | ;Am I enabled? | | | | 903 | | | initialize to receive fi | | | | 7B07 | 904 | | VOM | R3,#7 | ;BitCnt=7 (remaining) | | 024B | | 905 | | CLR | <b>A</b> | ;Data in A | | 024C | | 906 | | MOV | R4,A | ;ByteCnt=0 | | | 7E02 | 907 | | VOM | R6,#RXBIT | ;I2CCxt=receive next bit | | 024F | 411E | 908 | | AJMP | N8Bit | | | | | 909 | ; Conte | ext was | not waiting for Next bit | , ACK, or Idle slave. | | | | 910 | ; Could | l be ARI | <ol> <li>Dispatch other flags.</li> </ol> | | | | | 911 | ; Do no | t clear | DRDY, we'll come back a | fter ARL if necessary. | | 0251 | | 912 | NRxIdle | : | | | | | | 913 | | | | | | | | 914 | | | | | | | | 915 | \$EJ | | | | | | | 916 | ,***** | ***** | ******* | ***** | | | | 917 | ; It wa | sn't DF | RDY, could be ARL, START, | or STOP | | | | 918 | ; Handl | e ARL | | | | | | 919 | ;***** | ***** | ******* | ***** | | 0251 | 309C38 | 920 | NDRDY: | JNB | I2CON.ARL, RxStop | ;Is it ARL? | | | | 921 | | ;Yes, | note MASTRQ is still on | unless we were sending STOP. | | | | 922 | | | | it was a position report, | | | | 923 | | | | endRpt in case SndType is needed. | | 0254 | 30DE2E | 924 | ARL0: | JNB | I2CFG.MASTRQB,Naddr | ;Was I sending STOP? | | 0257 | E50B | 925 | | MOV | A, SndType | | | 0259 | B40305 | 926 | | CJNE | A, #LD_Position, ARL01 | ;Was I sending position? | | | 750B00 | 927 | | MOV | SndType, #I_NoMsg | | | | D219 | 928 | | SETB | SendRpt | | | | B4E405 | 929 | ARL01: | | A, #I_Error, ARL1 | ;Was I sending Error? | | | 750B00 | 930 | 1111111111 | MOV | SndType, #I_NoMsg | , mad I beliating billot. | | | D220 | 931 | | SETB | MsgCheck | | | | 301B19 | 932 | ARL1: | JNB | RxEnable,NAddr | ;Am I enabled? | | | 209B39 | 933 | WITT: | | I2CON.STR,SlvStart | | | | BC000A | 934 | | JB<br>CJNE | | ;Handle start. | | 0201 | PCOOOM | 934 | | | R4,#0,ARL3 | ;Did we ARL in Address (ByteCnt=0)? | | | | | | | ation in address, set con | | | 0070 | 750010 | 936 | | | in case message is to me. | | | | 759810 | 937 | ARL2: | VOM | I2CON, #CARL | ;Clear ARL. | | | 7E02 | 938 | | MOV | R6,#RXBIT | ;Set context waiting to read bit. | | | 209D80 | 939 | | JB | I2CON.DRDY,Rx0 | ; If DRDY, short cut. | | 027A | 21E5 | 940 | | AJMP | WaitATN | | | | | 941 | | | ation outside dst addr | | | | B4F006 | 942 | ARL3: | CJNE | A,#I_Reset,NAddr | ;Was I sending I_Reset to my Addr? | | | C21C | 943 | | CLR | TxSelfRst | ;Yes, reset flag since I lost. | | 0281 | C21F | 944 | | CLR | AA | ;Acknowledge received bytes. | | 0283 | 80ED | 945 | | SJMP | ARL2 | ;Message must be for me. | | | | 946 | ; Messa | age not | for me, go back to idle | receive. | | 0285 | | 947 | NAddr: | | | | | 0285 | 7598FC | 948 | IdleS: | VOM | I2CON, #CXA+IDLE+CARL+C | CDR+CSTR+CSTP | | | | | | | | | August 1992 523 | LOC | OBJ | LINE | SOURCE | | | |------|-------------|------|---------------------------------------|--------------------------|----------------------------------| | 0288 | 7E01 | 949 | MOV | R6, #RXIDLE | | | 028A | 21EC | 950 | AJMP | I2CRTI | | | | | 951 | \$EJ | | | | | | 952 | ;******** | r | | | | | 953 | ; Handle STOP | | ;*RC* Check for STOP first | | | | 954 | ;********* | • i a ija | | | 0280 | 309A16 | 955 | RxStop: JNB | I2CON.STP, RxStart | ;Confirm it was Stop. | | 028F | 759804 | 956 | MOV | I2CON, #CSTP | ;Clear it. | | 0292 | 201F04 | 957 | JB | AA,RxStop0 | ;Check end of message reached, | | | | 958 | · · · · · · · · · · · · · · · · · · · | 123,133.500 | ; Assert Acknowledge=1. | | | | 959 | : Rece | eived STOP before end of | | | 0295 | D220 | 960 | SETB | MsgCheck | ;Signal interface error. | | 0297 | D2DE | 961 | SETB | I2CFG.MASTRQB | , bigiai intellace elloi. | | | 7E01 | 962 | RxStop0: MOV | R6,#RXIDLE | ;Set context idle receiver. | | | 309E02 | 963 | JNB | I2CON.ATN, RxStop1 | ;If ATN, dispatch next event | | | : 21E0 | 964 | AJMP | DISPAT | , if Ain, dispatch next event | | | 759840 | 965 | RxStop1: MOV | I2CON, #IDLE | .Posema idla | | | 21EC | 966 | AJMP | | ;Become idle. | | VZAJ | LIDO | 967 | AUMP | I2CRTI | ;Resume interrupted activity | | | | 968 | ,******** | · · · | | | | | | • | | | | | | 969 | ; Handle START | | | | 0035 | 200007 | 970 | ;******* | | | | 02A5 | 309B07 | 971 | RxStart: JNB | I2CON.STR,RxFault | ;Was it start? | | | | 972 | SlvStart: | | | | | 759818 | 973 | MOV | I2CON, #CSTR+CARL | ;Yes, clear it. | | | 7000 | 974 | MOV | R4,#0 | ;ByteCnt=0 | | UZAD | 4138 | 975 | AJMP | SetRXB | ;Set up to receive byte. | | | | 976 | | | | | | | 977 | | RDY, ARL, START, or STOP | . Inconsistency error. | | 02AF | 01B4 | 978 | RxFault: AJMP | PwrUp | | | | | 979 | | | | | | | 980 | The second of | | | | | | 981 | \$EJ | | | | | | 982 | ;******** | ****** | | | | | 983 | ; MASTER TRANS | SMITTER | | | | | 984 | | R3=BitCnt, R4=ByteCnt, | R5=ATNCnt, R6=I2CCxt | | | | 985 | ; * * * * * * * * * * * * | ****** | | | | | 986 | ; Handle DRDY | | | | | | 987 | ;******** | ****** | | | 02B1 | EA | 988 | MASTER: MOV | A,R2 | ;Get data in A. | | 02B2 | 309D48 | 989 | JNB | I2CON.DRDY,MNDRDY | ;Is it DRDY? | | | | 990 | ; - context wa | iting to send bit | | | 02B5 | BE0418 | 991 | CJNE | R6, #TXBIT, NTxBit | ;Context waiting to send bit? | | 02B8 | F599 | 992 | Tx1: MOV | I2DAT, A | ;Send bit | | 02BA | 23 | 993 | Tx2: RL | A | ;Rotate the byte. | | 02BB | DB07 | 994 | DJNZ | R3,MN8Bit | ;Was it 8th bit? | | 02BD | 7E05 | 995 | MOV | R6, #TXREAD | ;Set context waiting to read ACK | | 02BF | 209D11 | 996 | <b>Ј</b> В | I2CON.DRDY, TxAck1 | ;If DRDY, short cut. | | 02C2 | 21E5 | 997 | AJMP | WaitATN | , if bibly bible ede. | | | | 998 | | | | | | | 999 | ; prep | pare next bit 1-7 | | | 02C4 | FA | 1000 | MN8Bit: MOV | R2,A | ; Put the data back. | | | 209DF0 | 1001 | JB | I2CON.DRDY,Tx1 | | | | 209DED | 1002 | JB | I2CON.DRDY,Tx1 | ; If DRDY, short cut. | | | 209DEA | 1003 | JВ | I2CON.DRDY,Tx1 | One more tru | | | 21E5 | 1004 | AJMP | WaitATN | ;One more try. | | | <del></del> | 1005 | AUNE | HATCAIN | | | | | 1005 | : - Context wa | iting to read ACK | | | 0200 | BE050D | 1007 | NTxBit: CJNE | | Contact witing t | | | | | TIADIC. CONE | R6, #TXREAD, NTxAck1 | ;Context waiting to read ACK? | | LOC OBJ | LINE | SOURCE | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | 02D3 7598A0 | 1008 | TxAck1: | MOV | I2CON, #CDR+CXA | | ;Switch to receive mode. | | | 02D6 7E06 | 1009 | | VOM | R6, #TXACK | | ;Set context waiting for A | ACK. | | 02D8 209D08 | 1010 | | JB | I2CON.DRDY,NTxAck2 | | ; If DRDY, short cut. | | | 02DB 23 | 1011 | | RL | <b>A</b> | | ;Align data in case ARL. | | | 02DC 1B | 1012 | | DEC | R3 | | | | | 02DD FA | 1013 | | MOV | R2,A | | | | | 02DE 21E5 | 1014 | | AJMP | WaitATN | | | | | 0208 2183 | 1015 | | 110111 | 7101 | | | | | | 1016 | | toxt wai | ting for ACK | | | | | 02E0 BE0620 | | | | R6, #TXACK, BeMast | | ;Context waiting for ACK? | | | 02E0 BE0629 | 1017 | NTxAck1 | | | | | | | 02E3 E598 | 1018 | NTxAck2 | | A, I2CON | | ;Read from I2CON | | | 02E5 5480 | 1019 | | ANL | A,#80h | | Only need 7th bit | | | 02E7 6005 | 1020 | | JZ | AckOK | | | | | 02E9 | 1021 | BadAck: | - | f negative ACK. | | | | | 02E9 D5097D | 1022 | | DJNZ | NACnt, DoStp1 | | ; Keep pending msg till re | try expires. | | 02EC 6166 | 1023 | | AJMP . | DoStp | | | | | | 1024 | | ;Ack Ok | ay, prepare to send | next | byte. | | | 02EE 0C | 1025 | AckOK: | INC | R4 | | ;Point to byte we want to | send. | | | 1026 | | ; ACALL | Sample | | | | | 02EF 81B1 | 1027 | | AJMP | DOTXB | | | | | | 1028 | | :return | should AJMP DNTXB | | | | | 02F1 EA | 1029 | DNTXB: | MOV | A,R2 | | ;Next byte in A. | | | 02F2 620D | 1030 | 3 1, 32 1, 1 | XRL | Check, A | | ; XOR with message check. | | | 02F4 7B08 | 1031 | | MOV | R3,#8 | | ;BitCnt=8 | | | | 1031 | | MOV | R6, #TXBIT | | ;Set context to send bit. | | | 02F6 7E04 | | | | I2CON.DRDY,Tx1 | | ;If DRDY, short cut. | | | 02F8 209DBD | 1033 | | JB | | | , II DRDI, SHOIC CUC. | | | 02FB 21E5 | 1034 | | AJMP | WaitATN | | | | | | 1035 | | | | | | | | | | | | | | | | | | 1036 | \$EJ | | | | | | | | 1037 | ;***** | ****** | ***** | | ***** | | | | 1037<br>1038 | ;*****<br>; It wa | | ************************************** | START, | or STOP. | | | | 1037 | ;*****<br>; It wa<br>; If AR | L, aligr | data with tx bit | START,<br>that 1 | or STOP.<br>ost arbitration | | | | 1037<br>1038 | ;*****<br>; It wa<br>; If AR | L, aligr | | START,<br>that 1 | or STOP.<br>ost arbitration | | | | 1037<br>1038<br>1039 | ;*****<br>; It wa<br>; If AR<br>; go to | L, aligr<br>handle | data with tx bit | START,<br>that 1<br>as cle | or STOP.<br>ost arbitration<br>ared). | | | | 1037<br>1038<br>1039<br>1040 | ;*****<br>; It wa<br>; If AR<br>; go to<br>; If it | L, aligr<br>handle<br>was STA | n data with tx bit of as SLAVE (MASTER wa | START,<br>that 1<br>as cle<br>maste | or STOP.<br>ost arbitration<br>ared). | | | | 1037<br>1038<br>1039<br>1040<br>1041 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST | L, align<br>handle<br>was STA<br>OP, not | n data with tx bit of<br>as SLAVE (MASTER wa<br>ART, we just became | START,<br>that 1<br>as cle<br>maste<br>rred, | or STOP. ost arbitration ared). r. | | | | 1037<br>1038<br>1039<br>1040<br>1041<br>1042 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho | L, align<br>handle<br>was STF<br>OP, not<br>ould have | n data with tx bit of<br>as SLAVE (MASTER wa<br>ART, we just became<br>sure how this occur | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. | | | 02FD 309C07 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho | L, align handle was STA OP, not buld have | n data with tx bit t<br>as SLAVE (MASTER wa<br>ART, we just became<br>sure how this occur<br>e seen ARL, become : | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. | | | | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STA OP, not buld have | n data with tx bit to as SLAVE (MASTER water) as SLAVE (MASTER water) as sure how this occur as seen ARL, become the t | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. | | | 0300 03 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STA OP, not uld have JNB | a data with tx bit of<br>as SLAVE (MASTER wa<br>ART, we just became<br>sure how this occur<br>e seen ARL, become<br>************************************ | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STF OP, not call have the street was wa | a data with tx bit of as SLAVE (MASTER water, we just became sure how this occur eseen ARL, become 12CON.ARL, MNARL A | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. ************************************ | | | 0300 03<br>0301 0B | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STA OP, not uld have the state of | n data with tx bit of as SLAVE (MASTER water, we just became sure how this occur seen ARL, become seen ARL, MARL AR3 | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STA OP, not ould have the state of th | an data with tx bit of as SLAVE (MASTER water), we just became sure how this occur eseen ARL, become seen ARL, become seen ARL, become and seen ARL, MARL AR3 | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STA OP, not ould have the state of th | an data with tx bit of as SLAVE (MASTER water than the sure how this occur is eseen ARL, become is the sure than the sure that the sure than the sure that t | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049<br>1050<br>1051 | ;******; It wa<br>; If AR<br>; go to<br>; If it; If ST<br>; sho<br>;******<br>MNDRDY: | L, align handle was STF OP, not uld have the street was street with the street was street with the street was street with the street was street was street was street was street was street with the street was s | an data with tx bit to as SLAVE (MASTER water), we just became sure how this occur eseen ARL, become statement of the sure how this occur as a sure how this occur as a sure how this occur as a sure how this occur as a sure how the | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049<br>1050<br>1051 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;***** | L, align handle was STA OP, not uld have the state of | a data with tx bit of as SLAVE (MASTER water than the source of sour | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049<br>1050<br>1051<br>1052 | ;******; It wa<br>; If AR<br>; go to<br>; If it; If ST<br>; sho<br>;******<br>MNDRDY: | L, align handle was STF OP, not uld have the street was street with the street was street with the street was street with the street was street was street was street was street was street with the street was s | an data with tx bit to as SLAVE (MASTER water), we just became sure how this occur eseen ARL, become statement of the sure how this occur as a sure how this occur as a sure how this occur as a sure how this occur as a sure how the | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049<br>1050<br>1051 | ;****** ; It wa ; If AR ; go to ; If it ; If ST ; sho ;***** MNDRDY: | L, align handle was STA OP, not uld have was STA OP, not uld have was standard or the standard of | an data with tx bit of as SLAVE (MASTER water, we just became sure how this occur is seen ARL, become is seen ARL, MNARL A R3 A R3 R2,A ARLO I2CON.STR, BeMast IdleS | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S<br>***** | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. ;Increment bit count. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049<br>1050<br>1051<br>1052 | ;****** ; It wa ; If AR ; go to ; If it ; If ST ; sho ;***** MNDRDY: | L, align handle was STA OP, not uld have was STA OP, not uld have was standard or the standard of | an data with tx bit of as SLAVE (MASTER water, we just became sure how this occur is seen ARL, become is seen ARL, MNARL A R3 A R3 R2,A ARLO I2CON.STR, BeMast IdleS | START,<br>that 1<br>as cle<br>maste<br>rred,<br>idle S<br>***** | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1049<br>1050<br>1051<br>1052<br>1053<br>1054 | ;******; It wa<br>; If AR<br>; go to<br>; If it<br>; If ST<br>; sho<br>;******<br>MNDRDY: | L, align handle was STA OP, not wild have was STA OP, not wild have was standard or the standard of standa | an data with tx bit of as SLAVE (MASTER water, we just became sure how this occur is seen ARL, become is seen ARL, MNARL A R3 A R3 R2,A ARLO I2CON.STR, BeMast IdleS | START, that 1 as cle maste rred, idle S ****** | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. ;Increment bit count. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1048<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055 | ;******; It wa ; If AR ; go to ; If it; ; If ST ; sho ;****** MNDRDY: MNARL: ; - cor ; Must | L, align handle was STA OP, not wild have "************************************ | an data with tx bit of as SLAVE (MASTER water, we just became sure how this occur is seen ARL, become is seen ARL, MARL A R3 A R4 ARLO 12CON.STR, BeMast IdleS | START, that 1 as cle maste rred, idle S ****** for bi Start | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. ;Increment bit count. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me | L, align handle was STF OP, not wild have the strength of | an data with tx bit of as SLAVE (MASTER water, we just became sure how this occur eseen ARL, become standard, become standard, become standard, and | START, that 1 as cle maste rred, idle S ****** for bi Start ype, d | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me | L, aligram handle was STF OP, not wild have the street of | an data with tx bit is as SLAVE (MASTER was SLAVE (MASTER was SLAVE), we just became sure how this occur eseen ARL, become seen ARL, become seen ARL, MARL A R3 A R2, A ARLO IZCON.STR, BeMast Idles ART or not waiting st become master. So pending in send to | START, that 1 as cle maste rred, idle S ****** for bi Start ype, d | or STOP. ost arbitration ared). r. LAVE. *********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02<br>030A 4185 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1050<br>1051<br>1052<br>1053<br>1054<br>1056<br>1057<br>1058 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me ; Other | L, aligram handle was STF OP, not wild have the street of | an data with tx bit of as SLAVE (MASTER water the sure how this occur is seen ARL, become is seen ARL, maker to a seek to send Position as sure as seen a seek to send Position as sure as seek to send Position as sure as seek and a seek to send Position as sure as seek as seek as a seek as | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. port if needed. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02<br>030A 4185 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056<br>1057 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me ; Other | L, align handle was STI handle was STI OP, not wild have with the state of stat | an data with tx bit of as SLAVE (MASTER water the sure how this occur is seen ARL, become is seen ARL, MNARL A R3 A R3 A ARLO IZCON.STR, BeMast Idles ART or not waiting st become master. Is pending in send to the seek to send Positic R1, SndType | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. tt or ACK (from above). new message. lo it. oort if needed. ;Get message type. | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02<br>030A 4185<br>030C A90B<br>030E B90043<br>0311 302007 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1047<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056<br>1057<br>1058 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me ; Other | L, align handle was STA handle was STA OP, not wild have was a state of the o | an data with tx bit is as SLAVE (MASTER was SLAVE (MASTER was SLAVE) as SLAVE (MASTER was SLAVE) as seen ARL, become seen ARL, become seen ARL, mark AR3 AR3 AR3 AR2,A ARL0 I2CON.STR, BeMast Idles ART or not waiting st become master. spending in send to seek to send Positic R1, SndType R1, #I_NoMsg, SndMsmsgCheck, BeMast1 | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. oort if needed. ;Get message type. ;No message pending? | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02<br>030A 4185<br>030C A90B<br>030E B90043<br>0311 302007<br>0314 750BE4 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056<br>1057<br>1058<br>1059<br>1060<br>1061<br>1062 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me ; Other | L, align handle was STA OP, not wild have was STA OP, not wild have was standard or wild have in the standard of the standard of the standard of the standard or wild have justified and standard or wild have justified wild have justified or been standard will have been standard or wild will sta | an data with tx bit is as SLAVE (MASTER was SLAVE (MASTER was SLAVE) as SLAVE (MASTER was SLAVE) as seen ARL, become seen ARL, become seen ARL, MARL AR3 AR3 AR3 AR2,A ARLO I2CON.STR, BeMast IdleS ART or not waiting st become master. Seen pending in send to be send Position R1, SndType R1,#I_NoMsg, SndMsmsgCheck, BeMast1 SndType,#I_Error | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. oort if needed. ;Get message type. ;No message pending? | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02<br>030A 4185<br>030C A90B<br>030E B90043<br>0311 302007<br>0314 750BE4<br>0317 C220 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056<br>1057<br>1058<br>1059<br>1060<br>1061<br>1062 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me ; Other | L, aligric handle was STF OP, not wild have the street of | an data with tx bit of as SLAVE (MASTER water the sure how this occur is seen ARL, become is seen ARL, become is seen ARL, MNARL A R3 A R2, A ARLO I2CON.STR, BeMast Idles ART or not waiting st become master. Is pending in send to be the send Positic R1, SndType R1, #I_NOMSg, SndMsm MsgCheck, BeMast1 SndType, #I_Error MsgCheck | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. oort if needed. ;Get message type. ;No message pending? | | | 0300 03 0301 0B 0302 03 0303 0B 0304 FA 0305 4154 0307 209B02 030A 4185 030C A90B 030E B90043 0311 302007 0314 750BE4 0317 C220 0319 6154 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056<br>1057<br>1058<br>1059<br>1060<br>1061 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - CON ; Must ; If me ; Other BEMAST: | L, aligram handle was STF OP, not wild have the street of | an data with tx bit of as SLAVE (MASTER water the sure how this occur is seen ARL, become is seen ARL, become is seen ARL, MNARL A R3 A ARLO IZCON.STR, BeMast Idles ART or not waiting st become master. Is pending in send to the seek to send Positic R1, SndType R1, #I_NoMsg, SndMsgCheck, BeMast1 SndType, #I_Error MsgCheck SndMsg | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. ort if needed. ;Get message type. ;No message pending? ;Send error? | | | 0300 03<br>0301 0B<br>0302 03<br>0303 0B<br>0304 FA<br>0305 4154<br>0307 209B02<br>030A 4185<br>030C A90B<br>030E B90043<br>0311 302007<br>0314 750BE4<br>0317 C220 | 1037<br>1038<br>1039<br>1040<br>1041<br>1042<br>1043<br>1044<br>1045<br>1046<br>1050<br>1051<br>1052<br>1053<br>1054<br>1055<br>1056<br>1057<br>1058<br>1059<br>1060<br>1061<br>1062 | ;****** ; It wa ; If AR ; go to ; If it; ; If ST ; sho ;***** MNDRDY: MNARL: ; - cor ; Must ; If me ; Other | L, aligram handle was STF OP, not wild have the street of | an data with tx bit of as SLAVE (MASTER water the sure how this occur is seen ARL, become is seen ARL, become is seen ARL, MNARL A R3 A R2, A ARLO I2CON.STR, BeMast Idles ART or not waiting st become master. Is pending in send to be the send Positic R1, SndType R1, #I_NOMSg, SndMsm MsgCheck, BeMast1 SndType, #I_Error MsgCheck | START, that 1 as cle maste rred, idle S ****** for bi Start type, on Rep | or STOP. ost arbitration ared). r. LAVE. ********** ;ARL? ;Rotate data back. ;Increment bit count. t or ACK (from above). new message. lo it. oort if needed. ;Get message type. ;No message pending? | | | LOC | OBJ | LINE | SOURCE | | | | |-------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 1067 | | | | | | | | 1068 | ; Send | Position | report | | | 0320 | 201C0C | 1069 | PosMsg: | JB | TxSelfRst,PosMsg1 | ;If first user data, | | 0323 | D21C | 1070 | | SETB | TxSelfRst | | | 0325 | 750BF0 | 1071 | | MOV | SndType, #I_Reset | ;Send a I_Reset to my address. | | 0328 | E508 | 1072 | | MOV | A, MyAddr | , <u>-</u> | | 032A | 750901 | 1073 | | MOV | NACnt,#1 | ;No retry if not acknowledged. | | 032D | 8027 | 1074 | | SJMP | SndMsg1 | , no recry ir not acknowledged. | | | 750B03 | 1075 | PosMsg1 | | SndType, #LD_Position | .Cond monition | | 0332 | | 1076 | rosmagi | CLR | SendRpt | ;Send position report. | | 0334 | | 1077 | 11 \$ 44 7 5 | | n in take di ≢arang kanang atau kanang balang kanang balang kanang balang balang balang balang balang balang b | ;Clear pending report state. | | 0335 | | | | CLR | A SERVICE STATE | Copy X-Y counts to xmt buffer. | | 0333 | | 1078 | | MOV | XBUF2,A | ;Hi byte=0. | | | | 1079 | | MOV | YBUF2, A | | | 0339 | | 1080 | | MOA | A, XCOUNT | ;Copy X. | | 033B | | 1081 | | MOV | XBUF1,A | | | | 30E703 | 1082 | | JNB | ACC.7,Copy2 | ; If negative, | | 0340 | 7512FF | 1083 | | MOV | XBUF2,#0FFh | ; extend sign. | | 0343 | E517 | 1084 | Copy2: | MOV | A, YCOUNT | ;Copy Y. | | 0345 | F515 | 1085 | | VOM | YBUF1,A | | | 0347 | 30E703 | 1086 | | JNB | ACC.7,Copy3 | ;If negative, | | 034A | 7514FF | 1087 | | MOV | YBUF2, #0FFh | ; extend sign. | | 034D | E4 | 1088 | Copy3: | CLR | A | , | | 034E | F516 | 1089 | | MOV | XCOUNT, A | ;Reset X-Y counters. | | 0350 | F517 | 1090 | | MOV | YCOUNT, A | Acade a 1 counters. | | 0352 | C21A | 1091 | | CLR | Movement | .01com | | 0354 | 7450 | 1092 | SndMsg: | | A, #Adr_Host | ;Clear movement flag. | | 0356 | | 1093 | SndMsg1 | | | 0.00 | | | 75981C | 1094 | Sildinsgi | | I2DAT, A | ;Send first bit by hand | | 0330 | 737010 | 1094 | | VOM | I2CON, #CARL+CSTR+CSTP | ;Clear start, release SCL | | 035B | RE OD | | | | ntext for rest of address | | | 035D | | 1096 | | MOV | Check, A | ;Init checksum | | | | 1097 | | MOV | R2,A | ;I2CDat=A | | 035E | | 1098 | | MOV | R3,#8 | ;BitCnt=8 | | 0360 | | 1099 | | MOV | R4,#0 | ;ByteCnt=0 | | 0362 | | 1100 | | MOV | R6, #TXBIT | ;Set context waiting to send bit | | 0364 | 41BA | 1101 | | AJMP | Tx2 | | | | | 1102 | \$EJ | | | | | | | 1103 | ; Comple | eted send | ding message, do STOP | | | 0366 | 750B00 | 1104 | DoStp: | VOM | SndType, #I_NoMsg | ;Indicate cmd no longer pending. | | 0369 | 717B | 1105 | DoStp1: | ACALL | SndStop | ; Send STOP. | | 036B | E50B | 1106 | | MOV | A, SndType | ; Is there a pending message? | | 036D | 7006 | 1107 | | JNZ | DoStp3 | , and a position of the contract contra | | 036F | 201903 | 1108 | | JB | SendRpt, DoStp3 | ;Is there a Position Report? | | 0372 | 302004 | 1109 | | JNB | MsgCheck, DoStp4 | ;Is there an error message? | | 0375 | 11AF | 1110 | DoStp3: | | SDelay | | | | | 1111 | | | nce to become master with | ;Yes, delay to give others | | 0377 | D2DE | 1112 | | SETB | I2CFG.MASTRQB | | | 0379 | | 1113 | DoStp4: | | RxStop0 | Request to be master again. | | 00,75 | | 1114 | Doscp4. | AUMP | RXSCODU | ;Borrow code from receiver. | | | | | G 3 | | elia e no la companione e | | | 037в | CSDE | 1115 | | I2C STOP | | | | | | 1116 | SndStop | | I2CFG.MASTRQB | ;Release Master request | | | 759821 | 1117 | | | I2CON, #CDR+XSTP | ;Set to send stop | | | 309EFD | 1118 | | | I2CON.ATN,\$ | ;Wait for ATN | | | 759820 | 1119 | | | I2CON, #CDR | ;Clear useless DRDY (rising SCL) | | | 309EFD | 1120 | | | I2CON.ATN,\$ | ;Wait for stop sent | | | 759894 | 1121 | | MOV | I2CON, #CARL+CSTP+CXA | ;Clear I2C bus | | 038C | | 1122 | | MOV | R6, #RXIDLE | ;Set context idle receiver. | | 038E | 22 | 1123 | | RET | | | | | | 1124 | er de la companya de<br>La companya de la co | | | | | | | 1125 | \$EJ | | | | | | | | | | | | ``` LOC OBJ LINE SOURCE ;********** 1126 1127 ; DO_RX_BYTE 1128 ; Received a complete byte, already acknowledged. 1129 ; Examine context to decide what to do with it. 1130 1131 ; Enter: R2 (I2CDat) is byte received. 1132 R4 is offset to byte just received. 1133 ; Exit: Command parameters saved as needed. 1134 Checksum verified. Valid commands executed. Return by AJMP DNRXB 1135 ; 1136 1137 R2=I2CDat, R3=BitCnt, R4=ByteCnt, R5=ATNCnt, R6=I2CCxt 1138 038F BC0002 DORXB: CINE R4.#0.DoRx1 ; Is it Address? (ByteCnt=0)? 1139 DNRXB 0392 4137 1140 AJMP 0394 BC0102 DoRx1: CJNE R4, #1, DoRx2 ; Is it source Addr? (ByteCnt=1) 1141 0397 4137 1142 AJMP DNRXB 1143 0399 EA 1144 DoRx2: MOV A,R2 ;Get byte. 039A BC020C 1145 CJNE R4,#2,DoRx3 ; Is it P+len? 0390 33 1146 RLC Α ;Rotate Prot bit into C. 039E 9218 1147 MOV Prot, C ;Save it. 03A0 EA 1148 MOV A,R2 ;Get "len". 03A1 547F A,#07Fh 1149 ANT. ; Add overhead. 03A3 2403 1150 ADD A,#3 03A5 F50C MOV 1151 MsgLen, A ; Save message length. 03A7 4137 DNRXB 1152 AJMP 1153 03A9 BC0304 1154 DoRx3: CJNE R4, #3, DoRx4 ; Is it Command byte? 03AC F50A 1155 MOV RcvType, A ;Save it 03AE 4137 AJMP DNRXB 1156 1157 $EJ 1158 ; Test for end of command 1159 1160 If command has no data, byte offset 4 will be the checksum. 03B0 E50C DoRx4: MOV ;Get message length. 1161 A.MsgLen A, ByteCnt, ToMny ; End of command? 03B2 B5040A 1162 CJNE 1163 ; sets carry if MsgLen<ByteCnt 03B5 D21F ; Yes, do not Acknowledge more bytes. 1164 SETR 03B7 E50D 1165 MOV A, Check ;Check in A 03B9 6002 1166 JΖ Check0k ;Bad check? 03BB 811F 1167 AJMP RxErr 1168 ; Message check is Ok, dispatch valid commands 03BD 8125 1169 CheckOk: AJMP DORXCMD ;Return AJMP DNRXB 1170 1171 ; Test for ByteCnt beyond message length 03BF 5002 1172 ToMny: JNC DoDat ;Too many bytes? 1173 ; Yes, just exit, negative acknowledge already sent. 03C1 4137 1174 DoRx9: AJMP 1175 1176 1177 ; Receive message data bytes 1178 ByteCnt from 4 to (MsgLen-1) 1179 ; Branch on RcvType to decide what to do with each byte. 1180 1181 ; Notice Reset, Identify, and Poll have no data. 1182 Protocol: Assign New Address, Capabilities request 1183 03C3 EA 1184 DoDat: MOV ;Get data again since DoRx4 wiped it. A,R2 ``` | | OBJ | LINE | SOURCE | | | | | | |--------|---------|------|--------|------------|--------------------|----------------------|------------------|------------| | 03C4 A | AF0A | 1185 | | VOM | R7, RcvType | ; Put RcvType in R7 | so we can CJNE | | | 03C6 3 | 3018F8 | 1186 | | JNB | Prot, DoRx9 | ; Ignore device data | a stream. | | | | | 1187 | | ; Proces | s C/S command by | tes. | | | | | | 1188 | | 4 31 35 | | | | | | | | 1189 | \$EJ | | | | | | | | | 1190 | ***** | ***** | ****** | ****** | | | | | | 1191 | | 3: Assign | ing the grants. | | | | | | | 1192 | | | | TD stades (Date Cal | 4 00 | | | | | | | | | ID string (ByteCnt= | 4-29). | | | | | 1193 | | | | l bit and ignore. | | | | | | 1194 | | | eCnt 30-31 with r | | | | | | | 1195 | ; If | not equ | al, ignore (beco | me idle receiver). | | | | | | 1196 | ; Save | ByteCnt | 32, the address | as parameter (R0). | | | | | | 1197 | ;***** | ****** | ******* | ****** | | | | | | 1198 | | | | 15 (1847) Sist | | | | 03C9 E | BFF225 | 1199 | Do5: | CJNE | R7,#I AsgnAdr.D | o6 ; Assign command? | | | | 03CC E | 3C040B | 1200 | | CJNE | R4,#4,Asn2 | ;Start of ID string | /PretoCate 412 | | | 03CF 7 | | 1201 | | MOV | R1,#0 | | | | | | | 1202 | | 110 ( | Ν1, πΟ | ;Initialize R1 is | index | | | | | | | | | | | | | 0251 5 | -0 | 1203 | | | t <= 29 | | | | | 03D1 E | | 1204 | Asn4: | MOV | A,R1 | ;Get offset | | | | 03D2 E | | 1205 | | ACALL | GET_ID | | | | | 03D4 0 | | 1206 | Asn5: | INC | R1 | ;Increment for next | : 1 | | | 03D5 E | 350215 | 1207 | | CJNE | A, I2CDAT, AsnIg | ;Compare to receive | ed byte | | | 03D8 4 | 1137 | 1208 | | AJMP | DNRXB | Ok so far | | | | | | 1209 | | 58 J. BAN. | | | | | | 03DA E | BC1E02 | 1210 | Asn2: | CJNE | R4,#30,Asn3 | ;ByteCnt=30? | | | | 03DD 7 | 790E | 1211 | | MOV | R1, #RandH | ;Yes, set to read r | -andom# | | | 03DF 4 | | 1212 | Asn3: | JC | ASN4 | ;Jump if less than | | | | | | 1213 | | 50 | ADNA | , bump it less than | 30. | | | | | | | | 20 | | | | | 0351 5 | 22204 | 1214 | | | nt >= 30 | | | 44.0 | | 03E1 B | | 1215 | | CJNE | R4,#32,Asn6 | ;ByteCnt=32? | | | | 03E4 A | | 1216 | | MOV | R0,I2CDat | ;Save new address i | n RO. | | | 03E6 4 | | 1217 | | AJMP | DNRXB | | | | | 03E8 5 | 5003 | 1218 | Asn6: | JNC | AsnIg | ;Jump if ByteCnt>32 | | | | 03EA E | 27 | 1219 | | MOV | A, @R1 | ;Get byte of random | ı #. | | | 03EB 8 | 30E7 | 1220 | | SJMP | Asn5 | ;Steal code from ab | | | | | | 1221 | | | | 84, 7 | | | | 03ED D | 21E | 1222 | AsnIg: | SETB | NotMyID | ;It's not for me | | | | 03EF 4 | 137 | 1223 | | AJMP | DNRXB | , it is not for me | | | | | | 1224 | | AUM | DINKAD | | | | | | | | | | | | | | | 0251 5 | mm2.2.1 | 1225 | | | apabilities Reque | | | | | 03F1 B | | 1226 | Do6: | CJNE | R7, #I_CapReq, Do7 | ;CapRequest | ? | | | 03F4 B | | 1227 | | CJNE | R4,#4,Cpr1 | ;ByteCnt=4? | | | | 03F7 E | | 1228 | | VOM | A,R2 | ;Check Cap | hi pointer=0? | | | 03F8 7 | | 1229 | | JNZ | Cpr4 | ;No, reset | length and offse | t to zero. | | 03FA B | C0516 | 1230 | Cpr1: | CJNE | R4, #5, Cpr9 | ;ByteCnt=5? | | | | | | 1231 | | ;Yes, c | heck for valid of | fset. | | | | 03FD E | 518 | 1232 | | MOV | A,CapOffset | ;Compute ne | vt offset | | | 03FF 2 | 519 | 1233 | | ADD | A, CapLen | , compate ne | AL OLLBEL. | | | 0401 B | | 1234 | | CJNE | A, I2CDat, Cpr2 | . Sama march | | | | 0404 8 | | 1235 | | | | ;Send next? | 1 7: 1: == | | | 0404 B | | | Cmm2 . | AJMP | Cpr8 | | to set offset. | | | | | 1236 | Cpr2: | MOV | A, R2 | ;A=received | | | | 0407 6 | | 1237 | | JZ | Cpr8 | ;Send first | | | | 0409 B | | 1238 | | CJNE | A,CapOffset,Cpr4 | ;Send previ | ous? | | | 040C 4 | | 1239 | | AJMP | DNRXB | ; Yes, use | current offset. | | | 040E E | | 1240 | Cpr4: | CLR | A | | th and offset to | zero. | | 040F F | 519 | 1241 | | MOV | CapLen, A | | | | | 0411 F | 518 | 1242 | Cpr8: | MOV | CapOffset,A | ;Load Cap o | ffset | | | 0413 4 | 137 | 1243 | Cpr9: | AJMP | DNRXB | , soud cap o | | | | | | | | | | | | | | LOC OBJ | LINE SOURCE | | | |--------------------------|---------------------------------------|---------------------------------------------------|-----------------------------------------------| | | 1244 | | | | | 1245 ; Set reportin | g Interval | | | 0415 BF8205 | 1246 Do7: CJNE | R7, #LD_SetInterval, Do7a | | | 0418 BC0402 | 1247 CJNE | R4,#4,Do7a | ;ByteCnt=4? | | 041B A802 | 1248 MOV | R0, I2CDat | ;Save parameter in RO. | | 041D 4137 | 1249 Do7a: AJMP | DNRXB | | | OdiD dis | 1250 | | | | | 1251 ; Command erro | or (T Error) | | | 041F D220 | 1252 RXETT: SETB | MsgCheck | ;Set to report error. | | | 1252 KXEII. SEIB | 12CFG.MASTROB | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | 0421 D2DE | | DNRXB | | | 0423 4137 | 1254 AJMP | DINKAB | | | | 1255 \$EJ | | | | | 1256 ;******** | **** | | | | 1257 ; DO_RX_CMD | | | | | | nd received, do it. | | | | | mmands based on RcvType | | | | 1260 ; Parameter v | alue is in RO. | | | | 1261 ; | | | | | 1262 ; Commands Re- | cognized: I_Reset, I_IdRe | q, I_AsgnAdr, I_CapReq, | | | 1263 ; | App_Test, App_P | oll, App_SetInterval | | | 1264 ; | | | | | 1265 ; Return is: | AJMP DNRXB. A is not pre | served. | | | 1266 ;******** | | | | 0425 AF0A | 1267 DORXCMD:MOV | R7, RcvType | ; Put RcvType in R7 so we can CJNE. | | 0427 201802 | 1268 JB | Prot, DoC4 | ;Go for Control/Status commands. | | 042A 4137 | 1269 AJMP | DNRXB | ; Ignore device data stream msgs. | | 042A 4137 | 1270 ADMI | Section 18 19 19 19 19 19 19 19 19 19 19 19 19 19 | , 1 g. 10 10 10 10 10 10 10 10 10 10 10 10 10 | | | | aammanda | | | | · · · · · · · · · · · · · · · · · · · | Commands | | | | 1272 ; Reset | D7 #T Bogot DoCE | | | 042C BFF002 | 1273 DoC4: CJNE | R7,#I_Reset,DoC5 | De never up woodt | | 042F 01B4 | 1274 AJMP | PwrUp | ;Do power up reset. | | | 1275 ; Identify | | | | 0431 BFF112 | 1276 DoC5: CJNE | R7,#I_IdReq,DoC6 | | | 0434 750BE1 | 1277 MOV | SndType, #I_IdReply | ;Message type is identify | | 0437 201D08 | 1278 JB | KeepID, RTBM | ;Keep same device number? | | 043A D21D | 1279 SETB | KeepID | | | 043C 858A0F | 1280 MOV | RandL, TL | ;Random number <- T0 | | 043F 858C0E | 1281 MOV | RandH, TH | | | 0442 D2DE | 1282 RTBM: SETB | I2CFG.MASTRQB | ;Request to be master | | 0444 4137 | 1283 AJMP | DNRXB | | | | 1284 ; Assign | | | | 0446 BFF20C | 1285 DoC6: CJNE | R7,#I_AsgnAdr,DoC7 | | | 0449 101E07 | 1286 JBC | NotMyID,NDo1 | ;Was it a complete match? | | 044C BC21D0 | 1287 CJNE | R4,#33,RxErr | ;Check len=30+3 | | 044C BC21D0<br>044F C21C | 1288 CLR | TxSelfRst | ;Anticipate first user data. | | 0451 8808 | 1289 MOV | MyAddr,R0 | ;Load new address | | 0451 8808 | | DNRXB | Though the desired | | 0453 4137 | 1290 Ndo1: AJMP | | | | | 1291 ; Capabilitie | | | | 0455 BFF30C | 1292 DoC7: CJNE | R7, #I_CapReq, DoC8 | el 1 1 1 1 2 2 2 | | 0458 BC0600 | 1293 CJNE | R4,#6,\$+3 | ;Check len>=3+3 | | 045B 40C2 | 1294 JC | RxErr | | | 045D 750BE3 | 1295 MOV | SndType, #I_CapReply | ;Message type is Cap Report | | 0460 D2DE | 1296 SETB | I2CFG.MASTRQB | ;Request to be master | | 0462 4137 | 1297 AJMP | DNRXB | | | | 1298 ; App Test | | | | 0464 BFB107 | 1299 DoC8: CJNE | R7, #App_Test, DoC9 | | | 0467 750BA1 | 1300 MOV | SndType, #App_TestReply | ;Send a test report | | 046A D2DE | 1301 SETB | I2CFG.MASTRQB | ;Request to be master. | | 046C 4137 | 1302 AJMP | DNRXB | | | 3100 1137 | | | | | | LOC | OBJ | LINE | SOURCE | | | | | | |---|--------------|--------|--------------|----------|----------|-----------------------------|-----------|-----------------------------|----| | | | | 1303 | ; App I | 2011 | | | | | | | 046E | BFB00D | 1304 | DoC9: | CJNE | P7 #ID Poll Doc | 10 | | | | | | E508 | 1305 | 2003. | MOV | R7,#LD_Poll,DoC1 A,MyAddr | LU | | | | | | B46E02 | 1306 | | CJNE | | 2-00- | ;Check for default address. | | | | | 8004 | 1307 | | SJMP | A, #Adr_Default, I<br>DoC9b | ос уа | | | | | | | 1308 | | DOM | Босэр | | ;Don't send Position report | s | | | 0478 | D219 | 1309 | DoC9a: | SETB | SendRpt | | ; to default address. | | | | | D2DE | 1310 | Boesa. | SETB | | | ;Flag to send Position repo | rt | | | 047C | 4137 | 1311 | DoC9b: | AJMP | I2CFG.MASTRQB<br>DNRXB | | ;Request to be master. | | | | | | 1312 | 20032. | 110111 | DINKAD | | | | | | | | 1313 | : Set I | ocator | report interval | | | | | | 047E | BF822E | 1314 | DoC10: | CJNE | R7, #LD_SetInterv | ral Docar | | | | | 0481 | BC0500 | 1315 | | CJNE | R4, #5, \$+3 | ar, DOCT. | | | | | 0484 | 4099 | 1316 | | JC | RxErr | | ;Check len>=2+3 | | | | 0486 | B80005 | 1317 | | CJNE | R0,#0,DoC10a | | · Choole | | | | | | 1318 | | | ameter=0, polling o | mlv | ;Check parameter range. | | | | 0489 | 758800 | 1319 | | MOV | TCON,#0 | TILY. | · Mr. o. o. o. o. o. | | | | 048C | 4137 | 1320 | | AJMP | DNRXB | | ;Turn off Timer0. | | | | 048E | B80800 | 1321 | DoC10a: | CJNE | RO, #8, \$+3 | | | | | | 0491 | 401A | 1322 | | JC | DoC10c | | ;Jump if RO<8. | | | | 0493 | B81A00 | 1323 | | CJNE | R0,#26,\$+3 | | 70 daily 11 K0 0. | | | | 0496 | 5015 | 1324 | | JNC | DoC10c | | ;Jump if R0>=26. | | | | | | 1325 | | ; 8 <= | = param <= 25, comp | ute Time | r0 reload value | | | | 0498 | 74FF | 1326 | | MOV | A,#OFFh | | ;Start at FFFFh | | | | 049A | F9 | 1327 | | MOV | R1,A | | , | | | | 049B | | 1328 | DoC10b: | CLR | C | | ;Loop to subtract | | | | | 949A | 1329 | | SUBB | A,#MSECL | | ; R0 milliseconds. | | | | 049E | | 1330 | | XCH | A,R1 | | | | | | 049F | | 1331 | | SUBB | A,#MSECH | | | | | | 04A1 | | 1332 | | XCH | A,R1 | | | | | | 04A2 | | 1333 | | DJNZ | R0,DoC10b | | | | | | 04A4 | | 1334 | | MOV | RTL,A | | ;Set Timer0 reload. | | | | 04A6 | | 1335 | | MOV | RTH,R1 | | | | | | | 758810 | 1336 | | MOV | TCON, #INIT_TCON | | Turn on Timer0. | | | | 04AB<br>04AD | | 1337 | | AJMP | DNRXB | | | | | , | UAAD | OIIF | 1338 | DoC10c: | AJMP | RxErr | | | | | | | | 1339<br>1340 | | | | | | | | ( | 04AF | 4137 | 1341 | ; unreco | gnizea | command (ignore it | =) | | | | | | 1137 | 1341 | DoC11: | AJMP | DNRXB | | | | | | | | 1343 | | | | | | | | | | | 1344 | \$EJ | | | - 4 | | | | | | | 1345 | ****** | ***** | **** | | | | | | | | 1346 | ; DOTXB | | | | | | | | | | 1347 | | itted. | a complete byte, ha | | | | | | | | 1348 | ; Get ne | ext byte | e based on context. | s been a | icknowledged. | | | | | | 1349 | ; Enter: | are by c | e based on context. | | | | | | | | 1350 | | ByteCn | t) is the offset of | | | | | | | | 1351 | ; Exit: | -3 | o, is the offset of | . che by | e we wish to send. | | | | | | 1352 | ; R2 ( | I2CDat | ) is the next byte | to trans | mit (if) | | | | | | 1353 | ; Ais | not p | reserved. | co crans | mic (II any). | | | | | | 1354 | | | AJMP DNTXB. | | | | | | | | 1355 | | | | | | | | | | | 1356 | ; R2=I | 2CDat, | R3=BitCnt, R4=Byte | Cnt. R5- | ATNCht P6-T2CC-+ | | | | | | 1357 | ;***** | ***** | ***** | , 1(J- | TOTAL RO-IZCOXE | | | | | | 1358 | ; - Sour | ce addı | ress | | | | | | | BC0104 | 1359 | | CJNE | R4,#1,DoTx1 ; | ByteCnt= | 1? | | | | 4B4 2 | | 1360 | 1793. | VOM | | | rce addr | | | 0 | 4B6 4 | 11F1 | 1361 | | AJMP | DNTXB | | | | | | | | | | | | | | | | LOC OBJ LINE | SOURCE | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1362 | | | | 1363 | ; - Message le | ength | | 04B8 BC0258 1364 | DoTx1: CJNE | R4,#2,DoTx2;ByteCnt=2? | | 04BB 7A82 1365 | VOM | R2,#082h ;Use 2 as default length, | | 1366 | | ; P=1, Control/Status msg. | | 04BD 750C05 1367 | MOV | MsgLen, #5 ;Include overhead | | 1368 | | oute length based on message type. | | 1369 | | not Position Report, Identify, Output Error, | | 1370 | | Reset, the length is 2. | | | MOV | R7, SndType | | 04C0 AF0B 1371 | | | | 1372 | ; Position rep | | | 04C2 BF0307 1373 | CJNE | R7, #LD_Position, TxA ; Position report? R2, #6 ; Data length is 6 (P=0, data stream). | | 04C5 7A06 1374 | MOV | | | 04C7 750C09 1375 | VOM | MsgLen, #9 ;6 plus 3 overhead. | | 04CA 41F1 1376 | AJMP | DNTXB | | 1377 | ; Attention | | | 04CC BFE00C 1378 | TxA: CJNE | R7,#I_Attn,TxI | | 04CF E51A 1379 | VOM | A, SelfTest ; Check for ROM error | | 04D1 B40105 1380 | CJNE | A, #ROM_ERROR, TxA9 | | 04D4 7A83 1381 | Len3: MOV | R2,#083h ;Use Len=3 to include checksum. | | 04D6 750C06 1382 | MOV | MsgLen, #6 | | 04D9 41F1 1383 | TxA9: AJMP | DNTXB | | 1384 | ; Identify Re | ply | | 04DB BFE107 1385 | TxI: CJNE | R7,#I_IdReply,TxC | | 04DE 7A9D 1386 | MOV | R2,#(80h+29) ;Length for Identify. | | | VOM | MsgLen, #(29+3); Add overhead for MsgLen | | | AJMP | DNTXB | | 04E3 41F1 1388 | | | | 1389 | ; Capabilitie | | | 04E5 BFE31C 1390 | TxC: CJNE | R7,#I_CapReply,TxE A.#CapFragLen ;Get default fragment length. | | 04E8 7410 1391 | MOV | | | 04EA F519 1392 | VOM | CapLen, A ;Save it. | | 04EC 2518 1393 | ADD | A,CapOffset ;Find end of fragment. | | 04EE C3 1394 | CLR | C | | 04EF 9475 1395 | SUBB | A, #(CAP_END-CAP_START) ; Is it beyond end of Cap String? | | 04F1 4006 1396 | JC | TxC3 ;No, use default length. | | 04F3 F4 1397 | TxC1: CPL | A ;Yes, shorten as needed. | | 04F4 04 1398 | INC | | | 04F5 2519 1399 | ADD | A, Caplen | | 04F7 F519 1400 | VOM | CapLen, A | | 04F9 E519 1401 | TxC3: MOV | A, CapLen ; Get fragment length. | | 04FB 2483 1402 | | A,#083h ;Compute data length. | | 04FD FA 1403 | | R2,A ;Prepare to send it. | | 04FE 2483 1404 | | A, #083h ;Add 3 overhead for MsgLen (clear C/S). | | 0500 F50C 1405 | | MsgLen, A | | 0502 41F1 1406 | | DNTXB | | 1407 | | r message framing error | | | | R7, #I_Error, TxR | | | | TxR1 | | 0507 8003 1409 | | and the second s | | 1410 | | P7 #I Pecet TvII | | 0509 BFF005 1411 | | R7,#I_Reset,TxU R2,#081h ;Length for Reset (80+1). | | 050C 7A81 1412 | the state of s | | | 050E 750C04 1413 | | MsgLen,#4 ;1 plus 3 overhead. | | 0511 41F1 1414 | TxU: AJMP | DNTXB | | 1415 | | | | 1416 | ; - Command | | | 0513 BC0309 1417 | DoTx2: CJNE | | | 0516 AA0B 1418 | MOV | R2, SndType ; Send command code | | 0518 BA0302 1419 | | | | 051B AA10 1420 | | R2, ReportBuf ; In that case send 1st byte of report. | | | | | | LOC | OBJ | LINE | SOURCE | | | | |--------|------------|------|---------------|-----------|------------------------------------------|---------------------------------------------------| | 051D | 41F1 | 1421 | TCC1: | AJMP | DNTXB | | | | | 1422 | ; | | | | | | | 1423 | ; - Te | st for 1 | ast byte of comm | and (message check) | | 051F | E50C | 1424 | | st: MOV | A, MsgLen | (marriage oncon) | | 0521 | B50404 | 1425 | | CJNE | | End ;Last byte of command? | | | | 1426 | | | | ; sets Carry if A <bytecnt< td=""></bytecnt<> | | 0524 | AA0D | 1427 | | MOV | R2,Check | ;Yes, send check. | | 0526 | 41F1 | 1428 | | AJMP | DNTXB | , res, send check. | | | | 1429 | | | 2 | | | | | 1430 | ,<br>To | et for h | eyond last byte | 5. C | | 0528 | 5005 | 1431 | DoTxEn | | | | | | 750905 | 1432 | DOTABLE | MOV | DoTx3 | ;Beyond last byte (check)? | | 052D | | 1433 | | | NACnt,#5 | Reset Negative Ack retry count. | | 0022 | 0100 | 1434 | | AJMP | DoStp | ; Send STOP. | | | | | | | | | | | | 1435 | | | | | | | | 1436 | | | sage data bytes | | | | | 1437 | | | 3 to (length+2) | | | | | 1438 | ; Dispa | atch bas | ed on command typ | | | 050- | | 1439 | | | | | | 052F | | 1440 | DoTx3: | MOV | R7, SndType | | | | BF0309 | 1441 | | CJNE | R7, #LD_Position | n,DoT3 ;Position report? | | 0534 | | 1442 | | MOV | A, ByteCnt | ;Yes, send next byte. | | 0536 | | 1443 | | ADD | A, #ReportBuf-3 | | | 0538 | F9 | 1444 | | VOM | R1,A | | | 0539 | 8702 | 1445 | | MOV | I2CDat, @R1 | ;R2=I2CDat=@R1 | | 053B | 41F1 | 1446 | | AJMP | DNTXB | | | | | 1447 | | | | | | | | 1448 | ;Attent | ion rep | ort | | | 053D | BFE009 | 1449 | DoT3: | CJNE | R7, #I_Attn, DoT4 | 1 | | 0540 | AA1A | 1450 | | MOV | R2,SelfTest | | | 0542 | BC0502 | 1451 | | CJNE | R4,#5,AT4 | ;Send Power-up selftest and attention ;ByteCnt=5? | | 0545 | AA1B | 1452 | | MOV | R2,RomSum | | | 0547 | 41F1 | 1453 | AT4: | АЈМР | DNTXB | ;Yes, send checksum byte. | | | | 1454 | ; | | DIVIND | | | | | 1455 | | ation to | est report | | | 0549 | BFA104 | 1456 | DoT4: | CJNE | | slv. DemE | | 054C | AA1A | 1457 | 2011. | MOV | R7, #App_TestRep | | | 054E | | 1458 | | AJMP | R2,SelfTest | ;Send Selftest result | | | | 1459 | | AUMP | DNTXB | | | | | 1460 | . * * * * * * | | e de | | | | | 1461 | | | ******* | | | | | | | ify repo | | | | | | 1462 | ; Send | I ID str | ing for ByteCnt 4 | -29 (26 bytes, last two are FFh). | | | | 1463 | ; Send | random | number for ByteC | nt 30 and 31. | | 0550 | ח 1 1 ממום | 1464 | | | ********** | | | | BFE11D | 1465 | DoT5: | CJNE | R7,#I_IdReply,D | oT6 | | 0553 | BC0409 | 1466 | | CJNE | R4,#4,IDR2 | ;First byte (ByteCnt=4)? | | | | 1467 | | ;yes, s | set up to send ID | string | | 0556 | 7900 | 1468 | | VOM | R1,#0 | ;R1 is index | | | - | 1469 | | | | | | 0558 | E9 | 1470 | IDR4: | VOM | A,R1 | ;Get offset | | 0559 | | 1471 | | ACALL | GET_ID | | | 055B | | 1472 | IDR5: | MOV | R2,A | ;Prepare to send it | | 055C | | 1473 | | INC | R1 | ;Increment for next | | 055D | 41F1 | 1474 | | AJMP | DNTXB | LOI MEXC | | | | 1475 | ; | | | | | 055F 1 | BC1E02 | 1476 | IDR2: | CJNE | R4,#30,IDR3 | ;ByteCnt=30? | | 0562 | | 1477 | | MOV | R1, #RandH | | | 0564 | | 1478 | IDR3: | JC | IDR4 | ;Set to send random #. | | | | 1479 | | | | ;Jump if less than 30. | | | | | | ' DA CCII | t >= 30 | | **AN445** ``` LINE SOURCE LOC OBJ CJNE R4, #32, $+3 0566 BC2000 1480 ;Jump if >= 32. JNC TDR7 0569 5003 1481 ;Get byte of random #. 1482 MOV A, @R1 056B E7 SJMP IDR5 056C 80ED 1483 ;Error! Beyond last byte, IDR7: AJMP DoStp 1484 056E 6166 ; STOP now. 1485 1486 ********* 1487 ; Capability report 1488 ; Send next byte of capability string. 1489 ; Uses R1 as index. 1490 ******* 1491 R7, #I_CapReply, DoT7 CJNE 1492 DOT6: 0570 BFE317 ;First byte (ByteCnt=4)? CJNE R4, #4, Cap1 0573 BC0404 1493 ; Send High byte of Offset (always 0). MOV R2,#0 1494 0576 7A00 AJMP DNTXB 1495 0578 41F1 1496 ;Second byte (Offsetlo)? R4, #5, CAP2 057A BC0506 1497 Cap1: CJNE ; Send Low byte of Offset. MOV R2,CapOffset 1498 057D AA18 R1, CapOffset ;Initialize R1 to use as index. MOV 057F A918 1499 AJMP DNTXB 0581 41F1 1500 1501 Cap2: MOV A,R1 ;Get Capabilities Character. 0583 E9 1502 ACALL GET_CAP 1503 0584 B1A9 ;Prepare to send it. R2,A 1504 MOV 0586 FA ; Increment for next Character. 0587 09 1505 INC Cap3: AJMP DNTXB 1506 0588 41F1 1507 ; Unknown: How can we not know what we're sending? 1508 DoT7: AJMP DNTXB 058A 41F1 1509 1510 1511 1512 $EJ ;*********** 1513 ; GET_ID 1514 1515 ; Get byte of ID string Enter: offset of desired byte in A. 1516 Exit: A is the desired byte. 1517 1518 GET_ID: INC ; Skip RET Α 058C 04 1519 A, @A+PC ;Get the byte MOVC 058D 83 1520 1521 RET 058E 22 ;ID string is defined here, length is 25 1522 ;Protocol revision DB 'A' 058F 41 1523 ; Module revision 'V1.1 0590 56312E31 1524 DB 0594 202020 'DEC ; Vendor name 0597 44454320 1525 DB 059B 20202020 DB 'VSXXX-BB' ; Module name 1526 059F 56535858 05A3 582D4242 0FFh ;1st byte of device # 05A7 FF 1527 DB ;2nd byte of device # 0FFh 05A8 FF 1528 DB 1529 ;****** 1530 1531 ; GET_CAP ; Get byte of Capabilities string. 1532 ; This implementation supports up to 254 bytes only! 1533 Enter: offset of desired byte in A. 1534 Exit: A is the desired byte. 1535 1536 ``` 533 August 1992 | | OBJ | LINE | SOURCE | | |------|----------|------|---------------|---------------------------------------| | 05A9 | 04 | 1537 | GET_CAP: INC | A ;Skip RET | | 05AA | 83 | 1538 | MOVC | A, @A+PC ;Get the byte | | 05AE | 3 22 | 1539 | RET | | | | | 1540 | ;Capabilities | string is defined here. | | 05AC | 28 | 1541 | CAP_START: DB | · · · · · · · · · · · · · · · · · · · | | 05AE | 2070726F | 1542 | DB | ' prot(locator)' | | 05B1 | 74286C6F | | | | | 05B5 | 6361746F | | | | | 05B9 | 7229 | | | | | 05BB | 20747970 | 1543 | DB | ' type(mouse)' | | 05BF | 65286D6F | | | | | | 75736529 | | | | | 05C7 | 20627574 | 1544 | DB | ' buttons(1(L)2(R)3(M))' | | 05CB | 746F6E73 | | | , , , , , , , , , , , , , , , , , , , | | 05CF | 2831284C | | | | | 05D3 | 29322852 | | | | | 05D7 | 2933284D | | | | | 05DB | 2929 | | | | | 05DD | 2064696D | 1545 | DB | ' dim(2)' | | 05E1 | 283229 | | | | | 05E4 | 2072656C | 1546 | DB | 'rel' | | 05E8 | 20726573 | 1547 | DB | ' res(200 inch)' | | 05EC | 28323030 | | | | | 05F0 | 20696E63 | | | | | 05F4 | 6829 | | | | | 05F6 | 2072616E | 1548 | DB | ' range(-127 127)' | | 05FA | 6765282D | | | | | | 31323720 | | | | | 0602 | 31323729 | | | | | 0606 | 20643028 | 1549 | DB | ' d0(dname(X))' | | 060A | 646E616D | | | | | 060E | 65285829 | | | | | 0612 | | | | | | 0613 | 20643128 | 1550 | DB | ' d1(dname(Y))' | | 0617 | 646E616D | | | | | 061B | 65285929 | | | | | 061F | 29 | | | | | 0620 | 29 | 1551 | DB | | | 0621 | 00 | 1552 | CAP_END: DB | 0 ;Null terminator (not used). | | | | 1553 | | length is 121 bytes | | | | 1554 | | | | | | 1555 | END | | | | | | | | **AN446** #### Author: Greg Goodhue The following program contains routines that will allow an 8xC751 or 8xC752 to implement a software UART that can send and receive serial data simultaneously. Other published software UARTs only allow either transmit or receive to occur at any one time. The demo application shown in the code listing waits for data to be received, then echoes it and follows this with a hexadecimal interpretation of the data plus a space. For instance, if the program receives the character "\$", it echoes back the string "\$24". The reason for echoing these additional characters is to make it easy to force the receiver buffer to fill up in order to test the handshaking. If the program simply echoed what was received, it would likely never use more than the very first receiver buffer location since it can normally transmit just as fast as it can receive. #### **CHIP RESOURCES** The UART routines use about 400 bytes of code space and use the timer to provide a constant time interrupt to synchronize both transmit and receive operations. The hardware connections require four device pins to accomplish serial I/O with RTS/CTS handshaking. Only two pins would be needed if handshaking is not required. Three of the four pin functions may be assigned to any port pin. The serial input pin must be assigned as one of the external interrupt pins. Another two pins are used in the demo application to input a selection of one of four baud rates (1200, 2400, 4800, or 9600). #### LIMITATIONS To obtain duplex operation, a fairly large portion of the chip's time is used. The routines were tested up to 9600 baud running on a 16 MHz 87C751. When serial input and output were both occurring at the same time, the routines could not support continuous operation with no pauses between characters. At 4800 baud, full speed tight reception and transmission worked flawlessly. In other words, 4800 baud should work with all applications, while 9600 baud may not work with all applications. #### THEORY OF OPERATION There are three possible sequences of events when serial transmit and receive may both be operating at once: transmit and receive begin simultaneously; transmit is requested while the receiver is busy; and receive starts while the transmitter is busy. The first 2 cases could be handled fairly simply with only one interrupt for each bit time. In the first case, everything is already in synch and only one timer and one interrupt per bit is needed to do both operations. In the second case (transmit is requested while the receiver is busy) the program could just wait for the next bit time to start transmitting. Unfortunately, the third case presents a problem. If the program is already transmitting, it cannot always wait for the next bit time to start sampling the serial data if the application is not to lose bits. Also, the timer cannot be adjusted to the incoming data since this would distort the duration of one of the transmitted bits. The method used here to deal with this problem is to always divide all bit times into 4 sub-bit times. When transmission and/or reception is in progress, the timer runs at 4X the bit rate for the selected baud rate. The variables TxTime and RxTime are used to count sub-bit times for the transmitter and the receiver, respectively. Both are initialized to a negative value and count up to simplify testing for an active sub-bit time. The maximum baud rate that can be supported is essentially determined by the maximum amount of time that it might take the microcontroller to do all of the operations associated with transmitting one bit and receiving one bit . This must be done within the time between timer interrupts. When both transmit and receive operations are scheduled for the same timer interrupt, priority is given to the transmitter routine. The reason for this is that a great deal of jitter can be tolerated in the timing of the received bit sampling, but the transmitted data must "look" good to the outside world. The actual bit times for transmit and receive are counted by the variables TxCnt and RxCnt, respectively. When an active sub-bit time slice occurs, these variables tell the transmit and receive routines what to do in the current time slice. The value 11 hex indicates a start bit, 10 hex indicates a stop bit, and the values 8 through F hex indicate a data bit. The values were chosen to allow quick determination of the appropriate action by the code. The routines provide for a small amount of data buffering for both the transmitter and the receiver. As implemented here, the transmitter buffer is only one byte deep, allowing one data byte to be held while another is being transmitted. The receiver buffer is larger, allowing three bytes to be held while a fourth is being received. If the receiver buffer fills up (indicated by the flag RxFull), the application code must retrieve one byte before a fourth one finishes, or data will be lost. If this happens, a flag will be set (OverrunErr) to indicate that the receiver buffer has been overrun. There is no similar flag for the transmitter, since the transmit request routine waits for the transmitter buffer to be available (indicated by the TxFull flag) before taking action. It is up to the application code to check this flag in advance if it does not want to stall execution while waiting to transmit data. As each routine finishes a whole data byte by completing the send or receive of a stop bit, it checks to see if there is something still happening to warrant having the time slice interrupt running. In the case of a received stop, the transmit activity flag (TxOn) is examined. If it is not set, the timer is turned off. The timer will be turned back on if an interrupt from a serial start bit is received or the main code requests data to be transmitted. In the case of a transmitted stop, both the receiver activity flag (RxOn) and the transmit buffer flag (TxFull) are examined. If the receiver is active or there is more data to transmit, the timer is left running. All of the status flags are in the "Flags" register. Other status flags found there are: RxAvail, which indicates that the receiver buffer contains unprocessed data; and FramingErr which is set when the receiver routines find an improper start or stop bit, usually caused by mismatched baud rates. Flow control handshaking is provided by the RTS/CTS scheme. The transmit routine looks at the incoming CTS line before beginning each start bit transmission, and simply exits, waiting for the next time slice, if CTS is not asserted. The receive routine checks the buffer status whenever a start bit interrupt occurs and de-asserts the outgoing RTS line if the buffer already contains two bytes (i.e., it will be full when the current byte finishes). If the device at the other end of the communication line follows the same rules (which may very well NOT be the case) the program should be able to communicate without buffer overflows in either direction. Baud rates in both the send and receive routines are determined by two things: the timer interrupt rate; and the number of time slices per bit. The method of calculating the timer value for various baud rates is discussed in the code listing at the BaudRate routine. This discussion has centered on there being four time slices per bit, but if the user wants, either the transmitter or the receiver can be set to run at a baud rate that is a multiple of the other by adjusting the value of the constant TxBitLen or RxBitLen. The baud rate would be calculated as indicated for the faster channel, and TxBitLen or RxBitLen would be changed for the slower channel. For example, the transmitter can be set to run at half of the receiver baud rate by setting TxBitLen to -8 + 1. **AN446** The routines shown also make provision for changing the baud rate "on the fly", although the application code given does not implement this feature. If the application code changes the baud rate for some reason, the change will be effected when the next data transmission or reception begins, if both the transmitter and receiver were already idle. This prevents the timer value from being changed in the middle of a data byte. #### THE CODE There are a number routines in the code of which the user should be aware: - Intr0—Called (by interrupt) when a serial start bit is received. - Timer0—Called (by interrupt) for every sub-bit time slice. - RS232TX—Called by Timer0 when the transmitter has business to conduct in the current time slice. - RS232RX—Called by Timer0 when the receiver has business to conduct in the current time slice. - BaudRate—Sets the baud rate variables - BaudHigh and BaudLow based on the accumulator value. - TxSend—Called by the application code to request that a data byte be transmitted. The data to be transmitted is in the accumulator. - GetRx—Called by the application code to request return of a received data byte from the buffer. Data is returned in the accumular. This routine should not be called unless the receiver buffer has data available. - Reset—Start of the initialization code to set up the UART. - MainLoop—Start of the mainline code of the demo application. **AN446** ``` Duplex UART Routines for the 8xC751 and 8xC752 Microcontrollers ************************ ; This is a demo program showing a way to perform simultaneous RS-232 ; transmit and receive using only one hardware timer. ; The transmit and receive routines divide each bit time into 4 slices to ; allow synchronizing to incoming data that may be out of synch with outgoing ; The main program loop in this demo processes received data and sends it ; back to the transmitter in hexadecimal format. This insures that we can ; always fill up the receiver buffer (since the returned data is longer than ; the received data) for testing purposes. Example: if the letter "A" is ; received, we will echo "A41 ". ************** $Title(Duplex UART Routines for the 751/752) SDate (8/20/92) $MOD751 *********************** Definitions ************************ : Miscellaneous ; Timer slices per serial bit transmit. TxBitLen EOU -4 + 1 ; Timer slices per serial bit receive. RxBitLen EQU -4 + 1 RxHalfBit EQU (RxBitLen / 4) + 1 ; Timer slices for a partial bit time. Used to adjust the input sampling time point. ; Note: TxBitLen and RxBitLen are kept separate in order to facilitate the possibility of having different transmit and receive baud rates. The timer would be set up to give four slices for the fastest baud rate, and the BitLen for the slower channel would be set longer for the slower baud rate. BitLen = -4 + 1 gives four timer interrupts per bit. BitLen = -8 + 1 would give 8 slices, BitLen = -16 + 1 would give 16 slices, etc. ; RS-232 transmit pin (output). TxPin BIT P1.0 ; RS-232 receive pin (input). BIT P1.5 RxPin ; RS-232 request to send pin (output). BIT P1.3 RTS ; RS-232 clear to send pin (input). BIT P1.6 ; Note: P1.1 and P1.2 are used to input the baud rate selection. ; RAM Locations : Miscellaneous bit flags (see below). DATA 20h Flags ; Indicates transmitter is on (busy). TxOn BIT Flags.0 ; Indicates receiver is on (busy). BIT Flags.1 RxOn ; Transmit buffer (1 byte only) is full. TxFull BIT Flags.2 ; Receiver buffer is full. RxFull BIT Flags.3 ; RX buffer is not empty. RxAvail BIT Flags.4 ; Overrun error flag. OverrunErr BIT Flags.6 ; Framing error flag. FramingErr BIT Flags.7 ; High byte timer value for baud rate. BaudHigh DATA 21h ; Low byte timer value for baud rate. DATA 22h BaudLow ; RS-232 byte transmit bit counter. TxCnt DATA 23h ; RS-232 transmit time slice count. DATA 24h TxTime DATA 25h ; Transmitter shift register. TxShift ; Transmitter holding register. TxDat DATA 26h ``` June 1993 537 **AN446** ``` RxCnt DATA 27h ; RS-232 byte receive bit counter. RxTime DATA 28h ; RS-232 receive time slice count. RxShift DATA 29h ; Receiver shift register. RxDatCnt DATA 2Ah ; Received byte count. RxBuf DATA 2Bh ; Receive buffer (3 bytes long). Temp DATA 2Fh ; Temporary holding register. Interrupt Vectors ORG 00h ; Reset vector. AJMP RESET ORG 03h ; External interrupt 0 AJMP Intr0 ; (received RS-232 start bit). ORG 0Bh ; Timer 0 overflow interrupt. AJMP Timer0 ; (4X the RS-232 bit rate). ORG 13h ; External interrupt 1. RETI ; (not used). ORG 1Bh ; Timer I interrupt. RETI ; (not used). ORG 23h ; I2C interrupt. RETT ; (not used). Interrupt Handlers ; External Interrupt Int0. RS-232 start bit transition. Intr0: PUSH ACC ; Save accumulator, PUSH PSW ; and status. CLR TE.O ; Disable more RX interrupts. SETB RxOn ; Set receive active flag. MOV RxCnt, #11h ; Set bit counter to expect a start. RxTime, #RxHalfBit ; First sample is at a partial bit time. MOV JB TxOn, IOTimerOn ; If TX active then timer is on. RTH, BaudHigh MOV ; Set up timer for selected baud rate. VOM RTL, BaudLow MOV TH, BaudHigh VOM TL, BaudLow SETB TR ; Start timer 0. IOTimerOn: MOV A, RxDatCnt ; Check for buffer about to be full: CJNE A, #2, IntOEx ; one space left and a byte starting. SETB RTS ; If so, tell whoever is on the other end to wait. Int0Ex: POP PSW ; Restore status, POP ACC ; and accumulator. RETI ; Timer 0 Interrupt This is used to generate time slices for both serial transmit and receive functions. ``` 538 June 1993 ``` ; Save accumulator, PUSH ACC Timer0: and status. PUSH PSW ; ; Is this an active time slice TxTime.7,RS232TX for an RS-232 transmit? ; If transmit is active, TxOn, CheckRx JNB . ; increment the time slice count. INC TxTime ; Is this an active time slice RxTime.7,RS232RX JNB CheckRx: for an RS-232 receive? ; If receive is active, increment JNB RxOn, TOEx ; the time slice count. TNC RxTime ; Restore status, POP PSW TOEx: ; and accumulator. ACC POP ; For demo purposes, output status P3,Flags MOV ; on an extra port. RETT RS-232 Transmit Routine ************************ ; Go if data bit. RS232TX: TxCnt.4,TxData ; Go if stop bit. TxCnt.0,TxStop ; Send start bit and do buffer housekeeping. CTS, TxEx1 ; Is CTS asserted (low) so can we send? JB TxStart: ; If not, try again after 1 bit time. ; Set start bit. TxPin CLR ; Get byte to transmit from buffer. TxShift,TxDat MOV CLR TxFull MOV TxCnt, #08h ; Init bit count for 8 bits of data. ; (note: counts UP). ; Reset time slice count. TxTime, #TxBitLen TxEx1: VOM ; Restore state and exit. SJMP CheckRx ; Send Next Data Bit. A,TxShift ; Get un-transmitted bits. TxData: MOV ; Shift next TX bit to carry. RRC ; Move carry out to the TXD pin. TxPin,C MOV TxShift, A ; Save bits still to be TX'd. MOM ; Increment TX bit counter INC TxCnt TxTime, #TxBitLen ; Reset time slice count. SJMP CheckRx ; Restore state and exit. ; Send Stop Bit and Check for More to Send. SETB TxPin ; Send stop bit. TxStop: ; More data to transmit? JВ TxFull, TxEx2 ; If not, turn off TX active flag, and CLR TxOn ; make sure that whoever is on the CLR RTS ; other end knows it's OK to send. RxOn.TxEx2 ; If receive active, timer stays on, ιTB ; otherwise turn off timer. CLR TxCnt, #11h ; Set TX bit counter for a start. TxEx2: TxTime, #TxBitLen-1 ; Reset time slice count, stop bit MOV ; > 1 bit time for synch. ; Restore state and exit. SJMP CheckRx ``` AN446 ``` ********************** RS-232 Receive Routine **************** RS232RX: MOV C, RxPin ; Get current serial bit value. JNB RxCnt.4, RxData ; Go if data bit. JNB RxCnt.0, RxStop ; Go if stop bit. ; Verify start bit. RxStart: JC RxErr ; If bit=1, then not a valid start. RxCnt,#08h MOV ; Init counter to expect data. MOV RxTime, #RxBitLen ; Reset time slice count. ; Restore state and exit. ; Get Next Data Bit. RxData: A, RxShift ; Get partial received byte. RRC ; Shift in new received bit. MOV RxShift,A ; Store partial result in buffer. INC RxCnt ; Increment received bit count. RxTime, #RxBitLen MOV ; Reset time slice count. SJMP TOEx ; Restore state and exit. ; Store Data Byte, "push"ing it into the FIFO buffer. RxStop: CLR ; Don't interrupt the following. MOV A, RxBuf ; "PUSH" the receive buffer. A,RxBuf+1 XCH A,RxBuf+2 MOV RxBuf, RxShift ; Add just completed data to buffer. INC RxDatCnt ; Increment the received byte count. SETB EA ; Re-enable interrupts. SETB RxAvail ; There is data in the RX buffer. PUSH PSW ; Save Carry (received bit) for later. ; Check receiver buffer status. MOV A, RxDatCnt CJNE A, #4, RxChk1 ; Is RX buffer overrun? SETB OverrunErr ; Set status reg overrun error flag. MOV RxDatCnt,#3 ; Re-set buffer counter to "full". RxChk1 · CJNE A, #3, RxChk2 ; Is RX buffer full? SETB RxFull ; Set buffer full status. RxChk2: POP PSW ; Retrieve last received bit in Carry. JC RxEx ; If bit=0, then not a valid stop. RxErr: SETB FramingErr ; Remember bad start or stop status. RxEx: TxOn, RxTimerOn JB ; If transmit active, timer stays on, CLR ; otherwise turn timer off. RxTimerOn: CLR RxOn ; Turn off receive active. SETB RxTime.7 ; Set bit for no service to RX Time Slice Branches. SETB IE.0 ; Re-enable RS-232 receive interrupts. AJMP TOEx ; Restore state and exit. Subroutines ; BaudRate - Determine and set the baud rate from switches. Note: if the baud rate is altered, the actual change will only occur when a transmit or receive is begun while the timer was not already running (i.e.: not already busy transmitting or receiving). ``` June 1993 ``` ; Set pointer to baud rate table. DPTR, #BaudTable BaudRate: ; Limit displacement for lookup. A,#03h ANL ; Double the table index since these RL Α are 2 byte entries. ; Save the table index for second byte. PUSH ACC ; Get first byte, and save as the high A, @A+DPTR MOVC byte of the baud rate timer value. MOV BaudHigh, A ; Get back the table index. POP ; Advance to next table entry. INC ; Get second byte, and save as the low A,@A+DPTR MOVC byte of the baud rate timer value. MOV BaudLow, A RET ; Entries in BaudTable are for a timer setting of 1/4 of a bit time at the given baud rate. The two values per entry are the high and low bytes of the value respectively. Values are calculated as follows: Osc Frequency 1/4 Bit cell time (in machine cycles) = ----- Baud Rate * 48 Example for 9600 baud with a 16MHz crystal: 16,000,000 / 9600 * 48 = 34.7222... machine cycles per quarter bit time. Rounded, this is 35. The hexadecimal value for 35 is 23. 10000 hex - 23 hex (truncated to 16 bits) = FFDD. Thus, the BaudTable entry for 9600 baud is FF, DD hex. ; 1200 baud. BaudTable: DB OFEh, OEAh DB 0FFh,75h ; 2400 baud. ; 4800 baud. OFFh, OBBh DB ; 9600 baud. DB OFFh, ODDh ; TxSend - Initiate RS-232 Transmit. ; Make sure TX buffer is free. JΒ TxFull,$ TxSend: ; Reserve the buffer for our use. TxFull SETB ; Put character in buffer. MOV TxDat, A ; Exit if transmitter already running. TxOn, TSTimerOn JB ; Transmit active flag set. TxOn SETB ; Init bit counter to expect a start. MOV TxCnt, #11h ; Reset time slice count. TxTime, #TxBitLen MOV ; Exit if receiver already active. RxOn, TSTimerOn JB ; Set up timer for selected baud rate. RTH . BaudHigh MOV MOV RTL, BaudLow TH, BaudHigh MOM TL, BaudLow SETB TR ; Start up the bit timer. TSTimerOn: ; PrByte - Output a byte as ASCII hexadecimal format. ; Print ACC contents as ASCII hex. PrByte: PUSH ACC SWAP A ; Print upper nibble. ACALL HexAsc ACALL TxSend ACC ; Print lower nibble. ACALL HexAsc ACALL TxSend ; HexAsc - Convert a hexadecimal nibble to its ASCII character equivalent. ; Make sure we're working with only A,#0Fh HexAsc: ANL one nibble. ; Test value range. CJNE A. #OAh, HA1 HA1: HAVal09 ; Value is 0 to 9. ``` ``` ADD A,#7 ; Value is A to F, needs pre-adjustment. HAVal09: ADD A,#'0' ; Adjust value to ASCII hex. RET ; \operatorname{GetRx} - \operatorname{Retrieve} a byte from the receive buffer, and return it in A. GetRx: CLR EΑ ; Make sure this isn't interrupted. DEC RxDatCnt ; Decrement the buffer count. MOV A, RxDatCnt ; Get buffer count. JNZ GRX1 ; Test for empty receive buffer. CLR RxAvail ; If empty, clear data available status. GRX1 · ADD A, #RxBuf ; Create a pointer to end of buffer. MOV Temp, R0 ; Save RO. MOV RO,A ; Put pointer where we can indirect. MOV A, @RO ; Get last buffer data. MOV R0, Temp ; Restore RO. CLR RxFull ; Buffer can't be full anymore. SETB EA ; Re-enable interrupts. RET ****************** Reset ******************* Reset: VOM SP,#2Fh ; Initialize stack start. MOV TCON, #0 ; Set timer off, INTO to level trigger. MOV P3,#0 ; Turn off all status outputs. ; For this demo, we only set up the baud rate once at reset: MOV A, P1 ; Read baudrate bits from P1. RR ; The switches are on bits 2 and 1. ACALL BaudRate ; Set up the selected baud rate. VOM FLAGS,#0 ; Init all status flags. VOM RxDatCnt,#0 ; Clear buffer count. MOV IE,#93h ; Turn on timer 0 interrupt and ; external interrupt 0. CLR ; Assert RTS so we can receive. ; The main program loop processes received data and sends it back to the transmitter in hexadecimal format. This insures that we can always fill up the receiver buffer (since the returned data is longer than the received data) for testing purposes. Example: if the letter "A" is received, we will echo "A41 ". JNB RxAvail,$ MainLoop: ; Make sure an input byte is available. ACALL GetRx ; Get data from the receiver buffer. ACALL TxSend ; Echo original character. ACALL PrByte ; Output the char in hexadecimal format, MOV A, #20h ; followed by a space. ACALL TxSend SJMP MainLoop ; Repeat. END ``` Philips Semiconductors Application note ## Using the 87C751 microcontroller to gang program PCF8582/PCF8581 EEPROMs **AN453** Author: David Chen, Shanghai Philips Technology Applications Lab #### SUMMARY This Application Note describes how to use the 87C751 microcontroller to implement a gang programmer for the Philips PCF8582 and PCF8581 I<sup>2</sup>C EEPROMs. Included are software, schematic, and PCB layout to allow copying from one 16-pin source EEPROM into ten slave EEPROMs. When the process is completed, a green LED turns on and a small buzzer sounds. A red LED by each slave socket indicates a failed IC. The PCF8582 is a 256x8 CMOS EEPROM with I<sup>2</sup>C interface. It comes in a variety of 8- and 16-pin plastic packages. This particular layout uses the 16-pin Dual In-Line package. The PCF8581 is a 128x8 CMOS EEPROM. This Gang Programmer was designed to program default set-up parameters into Philips Television sets which use I<sup>2</sup>C EEPROMs. The design is being presented here, not just to show how to make an I<sup>2</sup>C interfaced programmer, but to also serve as an example of using the 87C751 I<sup>2</sup>C interface. The programmer reads data from a source EEPROM and copies the data into ten slave EEPROMs. It can also compare the data between the master and the target. There are just two push buttons on the unit, Copy and Reset. Reset goes directly to the Reset pin on the '751, and shorts out the power-on reset capacitor. Copy is connected to INT0, and gets the micro's attention so that the copy process can start. The programmer is powered from a wall mount, 9V @ 300mA supply. A 5V regulator is on the board. A yellow LED is used to indicate that power has been applied to the board. A green and a pink LED indicate the status of the programming operation, and there is a red LED at each socket to indicate a failure in the programming process to that IC. If everything goes well, the green LED will signal the successful completion of the programming process and a buzzer will also sound. The pink LED will come on if there are any errors in any EEPROM, and the appropriate red LED will indicate the faulty IC. If the pink LED is on and none of the red LEDs are on, there has been an error in the I<sup>2</sup>C communication link. #### **OPERATION** Since the PCF8582 only has three Chip Select lines, and there are eleven parts in the system, a different addressing scheme had to be devised. In this system, A0 and A1 have four possible combinations of addresses. A2 is then used as a bank select which is driven by P1.2, P1.3 and P1.4 on the '751. The 10 red LEDs and the pink and green LEDs are multiplexed, since there are not enough port pins left to directly drive them. Port 3 drives a 74LS244 which in turn drives the anodes of the LEDs through $100\Omega$ resistors. The two banks for the multiplexing are driven to ground by discrete transistors which receive their base drive from P1.0 and P1.1. Jumpers on P1.6 and P1.7 are used to select different options. Jumpering P1.6 to ground selects the PCF8581 and leaving that jumper off selects the PCF8582. If P1.7 is jumpered to ground, the programmer will only do a compare between the source and the slaves. This compare operation is done in 16-byte segments. If no jumper, then the normal programming sequence will be done. #### **Program Flow** - 1. Turn on source EEPROM and initialize '751 pointers in RAM - 2. Read two bytes of source data - 3. Enable target EEPROM array - 4. Write the 2-byte data to each of the ten targets - 5. Increment subaddress and get next data from source - 6. Repeat write to other targets - 7. Wait 70ms to allow the information to be written internally to the EEPROM cells - 8. Read each target to verify that correct write was done - 9. Repeat the 2-byte write and read cycles until done - 10. Disable EEPROM power and turn on the green LED and beep - 11. Wait for next input The '751 keeps track of any problems with the programming process, and it skips the verify and subsequent programming of bad or missing targets. AN453 **(1)** AN453 SU00514 $\oplus$ ``` PCF85XX PROGROMER вч S C 8 7 C 7 5 1 EDITOR: DAVID Y. CHEN SHANGHAI PHILIPS TECHNIOLOGY APPLICATION LAB. ** TEL: 86-21-3777760 $Title(PCF8582/8581 Programmer Source Code) $Mod751 $Debug PORT DEFINITIONS PORT 0 PO.4 PO.3 P0.7 P0.6 P0.5 P0.2 P0.1 P0.0 P0.2 Power ; Power supply for eeprom PORT 1 P1.7 P1.6 P1.5 P1.4 P1.3 P1.2 P1.1 BComp B8582 GO Group1 Group2 Group3 Col02 Col01 BComp BIT P1.7 ;Option for compare only when "0" B8582 BIT P1.6 ;Option for PCF8581 when "0" GO BIT P1.5 ;Copy start key input P1.4 Group1 BIT ;eeprom group 1 Group2 BIT P1.3 ;eeprom group 2 ;eeprom group 3 Group3 BIT P1.2 Co102 BIT P1.1 ;LED display column 2 Co101 BIT P1.0 ;LED display column 1 PORT 3 (LED display output) P3.7 P3.6 P3.5 P3.4 P3.3 P3.2 LED11 LED09 n.c. BUZZER LED07 LED05 LED03 LED01 /LED12 /LED10 /LED08 /LED06 /LED04 /LED02 BZ BIT P3.4 ;Beep output REGISTER DEFINITION REGISTER BANK 0 RO,R1,R2: FREE R3: EEPROM Slave Address Buffer R4: EEPROM Subaddress Buffer ``` ``` R5: EEPROM Number Counter ; R6: EEPROM Group Counter R7: RAM Buffer Pointer EQUIVALENT DEFINITION _____ BIT0 EQU 1 2 BIT1 EOU BIT2 EQU 8 BIT3 EQU 010H EQU BTT4 EQU 020H BIT5 040H BIT6 EQU 080H втт7 EQU EOU OFEH CBTT0 CBIT1 OFDH 0FBH CBIT2 EQU EQU OF7H CBTT3 CBIT4 EQU 0EFH CBIT5 EQU ODFH 0BFH CBTT6 EQU CBIT7 07FH ;Source eeprom slave address SourceAdr EQU 0ACH ;Target eeprom slave address 0A8H TargetAdr EQU ;Timer reload for 5 mSec -200 RTNI. EQU RTNH EOU -20 ;Timer reload ; Masks for I2CFG bits. EQU BIT5 ;CT1, CT0 bit values for I2C. EQU BIT1 CTVAL BIT4 ; Mask for TIRUN bit. EQU BTIR ; Mask for MASTRQ bit. EQU BIT6 ; Masks for I2CON bits. ; Mask for CXA bit. EQU BIT7 BCXA ; Mask for IDLE bit. EQU BIT6 BIDLE ;Mask for CDR bit. BCDR EQU BIT5 EQU :Mask for CARL bit. BCARL BIT4 ; Mask for CSTR bit. EQU BIT3 BCSTR ; Mask for CSTP bit. BCSTP EQU BIT2 ; Mask for XSTR bit. BIT1 BXSTR EQU ; Mask for XSTP bit. BXSTP EQU BIT0 ;Register redefinition ;Slave address buffer SlvAdr EQU ;Slave subadress buffer SubAdr EQU R4 RAM and BIT Defination LEDRAM1 DATA 28H ; EEPROM status register1 BIT7 BIT6 BIT5 BIT4 BIT3 BIT2 BIT1 BIT0 BEP1 LED07 LED05 LED03 LED01 LED11 LED09 ``` ``` BWAIT BIT LEDRAM1.7 ;Wait_LED bit (LED11) BLED09 BIT LEDRAM1.6 ; EEPROM_LED09 bit BEP1 BIT LEDRAM1.4 ; BUZZER BLED07 BIT LEDRAM1.3 ;EEPROM_LED07 bit BLED05 BIT LEDRAM1.2 ; EEPROM_LED05 bit BLED03 BIT LEDRAM1.1 ; EEPROM_LED03 bit BLED01 BIT LEDRAM1.0 ; EEPROM_LED01 bit LEDRAM2 DATA 029H ; EEPROM status register2 BIT6 BIT5 BIT4 BIT3 BIT2 BIT1 BIT0 LED12 LED10 BEP2 LED08 LED06 LED04 LED02 BERROR BIT LEDRAM2.7 ;Error_LED bit (LED12) BLED10 BIT LEDRAM2.6 ; EEPROM_LED10 bit BEP2 BIT LEDRAM2.4 ; BUZZER BLED08 BIT LEDRAM2.3 ; EEPROM_LED08 bit BLED06 BIT LEDRAM2.2 ;EEPROM_LED06 bit BLED04 BIT LEDRAM2.1 ; EEPROM LED04 bit BLED02 BIT LEDRAM2.0 ; EEPROM_LED02 bit Flags DATA 02AH ;Software status flags. NoAck BIT Flags.0 ; Indicates missing acknowledge in I2C Fault BIT Flags.1 ; Indicates a bus fault of some kind. Retry BIT Flags.2 ; Indicates that last I2C transmission ; failed and should be repeated. BGo BIT Flags.3 ;Flag of Copy_key input BCo1 BIT Flags.4 ;Flag of LED display column BBZ BIT Flags.5 ;Flag of Buzzer output ; RAM locations used by I2C routines. BitCnt DATA 2BH ;I2C bit counter. ByteCnt DATA ;Byte counter RcvDat. DATA 2DH ;start address of transmit buffer XmtDat DATA 2Eh ;start address of transmit buffer StackSave DATA 2Fh ; Saves stack address for bus recovery. Stack DATA 30H ;Stack address GENERAL INTERRUPT ROUTINE ORG 00H :Reset AJMP POR ;Power on reset proc ORG 03H AJMP GOIN ;Copy_key input ORG 0вн ;Counter/Timer0 interrupt AJMP Timer ORG 13H RETI ;No external interrupt1 used ORG 1BH ;Timer I (I2C timeout) interrupt AJMP TimerI ORG 23H ;No I2C interrupt used RETI ``` AN453 ``` I2C bus time our proc ;Clear timer I interrupt. TimerI: SETB CLRTI CLR TIRUN ;Clear interrupt pending. ACALL ClrInt SP, StackSave ;Restore stack for return to main. MOV AJMP Recover ;Attempt bus recovery. ClrInt: RETT Timer 0 interrupt proc ______ ;TimerO interrupt is used for LED scan (5mSec period) Timer: JB BCol, Timer1 ;If LED_column 2 was in display ;Drive LED_column 1 MOV P3,LEDRAM1 ;Turn off LED_column 2 SETB COL02 CLR COL01 ;Light LED_column 1 AJMP Timer2 Timer1: VOM P3, LEDRAM2 ;Drive LED column 2 COL01 ;Turn off LED column 1 SETB CLR COL02 ;Light LED_column 2 Timer2: CPL BCol ;Compl. flag of LED column RETI _____ External Interrupt 0 proc ;External interrupt 0 is used to accept Copy_key input GOIN: SETB BGo ;Set flag for Copy_key input RETI Send data byte(s) to EEPROM ______ ; Entry: SlvAdr = slave address SubAdr = subaddress of eeprom ByteCnt = # of bytes to be sent XmtDat = start address of transmit buffer ; Return: NoAck, Retry flags ;Clear error flags. SendData: CLR NoAck CLR Fault CLR Retry ; Save stack address for bus fault. VOM StackSave, SP ;Get slave address. VOM A,SlvAdr ;Get bus and send slave address. ACALL SendAddr NoAck, SDEX JB ;Check for missing acknowledge. Fault, SDatErr ; Check for bus fault. JB A, SubAdr ;Get slave subaddress. VOM ;Send subaddress. ACALL XmitByte ;Check for missing acknowledge. NoAck, SDEX JΒ Fault, SDatErr ;Check for bus fault. JΒ MOV R0,XmtDat ;Set start of transmit buffer. ``` AN453 ``` SDLoop: MOV A, @RO ;Get data for slave. INC R0 ACALL XmitByte ;Send data to slave. JB NoAck, SDEX ; Check for missing acknowledge. JB Fault, SDatErr ;Check for bus fault. DJNZ ByteCnt, SDLoop ; If ByteCnt not zero. ; Then continue send data. SDEX: ACALL SendStop ;Else send an I2C stop. RET ; Handle a transmit bus fault. SDatErr: AJMP Recover ;Attempt bus recovery. Receive data bytes from EEPROM _____ SlvAdr = slave address SubAdr = subaddress of eeprom ByteCnt = # of data bytes to be read RcvDat = start address of receive buffer ; Return: NoAck, Retry, Data in RcvDat buffer RcvData: CLR NoAck ;Clear error flags. CLR Fault CLR Retry MOV StackSave, SP ; Save stack address for bus fault. MOV A, SlvAdr ;Get slave address. ACALL SendAddr ;Send slave address. .TR NoAck, RDEX ; Check for missing acknowledge. JB Fault, RDatErr ;Check for bus fault. MOV A, SubAdr ;Get slave subaddress. ACALL XmitByte ;Send subaddress. JB NoAck, RDEX ; Check for missing acknowledge. JB Fault,RDatErr ;Check for bus fault. ACALL. RepStart ;Send repeated start. JB Fault, RDatErr ; Check for bus fault. MOV A, SlvAdr ;Get slave address. SETB ACC.0 ;Set bus read bit. ACALL SendAd2 ;Send slave address. JB NoAck, RDEX ; Check for missing acknowledge. JB Fault,RDatErr ;Check for bus fault. MOV R0, RcvDat ;Set pointer of receive buffer. DJNZ ByteCnt, RDLoop ; If ByteCnt = 1 SJMP RDLast ; Then goto receive last byte RDLoop: ACALL RDAck ;Get data and send an acknowledge. JB Fault,RDatErr :Check for bus fault. MOV @RO,A ; Save data. ; Increase receive buffer pointer. INC R0 DJNZ ByteCnt, RDLoop ; Repeat until last byte. ACALL RDLast: RcvByte ;Get last data byte from slave. Fault, RDatErr JB ; Check for bus fault. MOV @RO,A ;Save data. MOV I2DAT, #80h ; Send negative acknowledge. JNB ATN,$ ;Wait for NAK sent. JNB DRDY, RDatErr ;Check for bus fault ``` AN453 ``` SendStop ; Send an I2C bus stop. RDEX: ACALL RET ; Handle a receive bus fault. Recover ;Attempt bus recovery. RDatErr: AJMP I2C Bus proc subroutine ; Send address byte. Enter with address in ACC. I2CFG, #BMRQ+BTIR+CTVAL ; Request I2C bus. SendAddr: ;Wait for bus granted. JNB ATN, S JNB Master, SAErr ; Should have become the bus master. ;Send first bit, clears DRDY. SendAd2: MOV I2DAT, A I2CON, #BCARL+BCSTR+BCSTP ; Clear start, releases SCL. ; Finish sending address. XmitAddr ACALL RET ;Return bus fault status. SETB Fault SAErr: ______ ; Byte transmit routine. Enter with data in ACC. XmitByte : transmits 8 bits. XmitAddr : transmits 7 bits (for address only). ;Set 7 bits of address count. BitCnt,#8 XmitAddr: VOM XmBit2 SJMP ;Set 8 bits of data count. MOV BitCnt,#8 XmitByte: ;Send this bit. XmBit: MOV I2DAT, A ;Get next bit. XmBit2: RL DRDY,XMErr ;Should be data ready. BitCnt,XmBit ;Repeat ..... JNB JNB ;Repeat until all bits sent. DJNZ VOM I2CON, #BCDR+BCXA; Switch to receive mode. ;Wait for acknowledge bit. JNB ATN,$ ;Was there an ack? JNB RDAT, XMBX SETB NoAck ;Return no acknowledge status. XMBX: RET ;Return bus fault status. SETB Fault XMErr: RET ; Byte receive routines. RDAck : receives a byte of data, then sends an acknowledge. RcvByte : receives a byte of data. Data returned in ACC. ;Receive a data byte. RDAck: ACALL RcvByte ;Send receive acknowledge. I2DAT,#0 MOV ;Wait for acknowledge sent. JNB ATN,$ ;Check for bus fault. JNB DRDY, RdErr RET RcvByte: VOM BitCnt,#8 ;Set bit count. ;Init received byte to 0. CLR ``` ``` RBit: A, I2DAT ORL Get bit, clear ATN. RL ;Shift data. JNB ATN, S ;Wait for next bit. ;Should be data ready. JNB DRDY, RdErr DJNZ BitCnt, RBit ;Repeat until 7 bits are in. MOV C, RDAT ;Get last bit, don't clear ATN. RLC ;Form full data byte. RET RdErr: SETB Fault ;Return bus fault status. RET ______ ; I2C stop routine. SendStop: CLR MASTRQ ; Release bus mastership. MOV I2CON, #BCDR+BXSTP; Generate a bus stop. ATN,$; Wait for atn. I2CON,#BCDR; Clear data ready. JNB MOV JINB ATN,$ ;Wait for stop sent. I2CON, #BCARL+BCSTP+BCXA ;Clear I2C bus. MOV CLR TIRUN ;Stop timer I. RET ; I2C repeated start routine. Enter with address in ACC. RepStart: MOV I2CON, #BCDR+BXSTR; Send repeated start. JNB ATN,$ ;Wait for data ready. JNB STR,$ ;Wait for repeated start sent. MOV I2CON, #BCARL+BCSTR ;Clear start. RET ; Bus fault recovery routine. Recover: MOV I2CFG, #BCLRTI+CTVAL ; Request I2C bus. ACALL FixBus ;See if bus is dead or can be 'fixed'. JC BusErr ;If not 'fixed' SETB Retry ; If bus OK, return to main routine. CLR Fault CLR NoAck SETB TIRUN ;Enable timer I. RET ; This routine tries a more extreme method of bus recovery. This is used if SCL or SDA are stuck and cannot otherwise be freed. (will return to the Recover routine when Timer I times out) BusErr: CLR MASTRO ;Release bus. MOV I2CON, #0BCh ;Clear all I2C flags. MOV LEDRAM1,#0FFH ;Turn on all of LEDs MOV LEDRAM2, #0FFH ACALL Beep ;Beep alarm for bus error SJMP $-4 ; This routine attempts to regain control of the I2C bus after a bus fault. Returns carry clear if successful, carry set if failed. FixBus: CLR MastRO ;Turn off I2C functions. SETB С SETB SCL ; Insure I/O port is not locking I2C. SETB SDA JNB SCL, FixBusEx ; If SCL is low, bus cannot be 'fixed'. JB SDA, RStop ; If SCL & SDA are high, force a stop. ``` | FixBus1: | VOM | BitCnt,#9 | ;Set max # of tries to clear bus. | |-----------|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ChekLoop: | CLR | SCL | ;Force an I2C clock. | | | ACALL | SDelay | | | | JB | SDA, RStop | ;Did it work? | | | SETB | SCL | | | | ACALL | SDelay | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | DJNZ | BitCnt,ChekLoop | Repeat clocks until either SDA clears | | | | | ; or we run out of tries. | | | SJMP | FixBusEx | ;Failed to fix bus by this method. | | RStop: | CLR | SDA | Try forcing a stop since SCL & SDA | | | ACALL | SDelay | ; are both high. | | | SETB | SCL | | | | ACALL | SDelay | alient water in the second of | | | SETB | SDA | | | | ACALL | SDelay | | | | JNB | SCL, FixBusEx | ;Are SCL & SDA still high? If so, | | | JNB | SDA, FixBusEx | ; assume bus is now OK, and return | | | CLR | C | ; with carry cleared. | | FixBusEx: | RET | | | | ; | | | | | | | | | | ; | | | <del> </del> | | ; | Power | on reset for I/O a | and RAM initialization | | ; | | | | | | | | | | POR: | MOV | PO,#03H | ;Switch power supply on for eeprom | | | MOV | P1,#0E3H | ;Init. port 1 and disable eeproms | | | MOV | P3,#30H | ;Turn off all of LEDs | | | | | | | | MOV | RO,#63 | ;Load RAM counter for clear loop | | ResRAM: | MOV | @RO,#0 | | | | DJNZ | R0,ResRAM | | | | | | | | | JNB | SCL, BusErr | ; If SCL low then bus error & can't be fixed | | | JB | SDA, InitDsp | ;Else If SDA high then bus ok | | | SETB | | ; Else go to fix bus | | | ACALL | FixBus1 | , ,, ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | JC | BusErr | ; If bus not fixed then goto error alarm | | | 00 | Dubli | 711 245 1105 111104 011011 5000 01111 01111111111 | | Tni+Dan. | CEMP | POWER | ;Switch power supply off for eeprom | | InitDsp: | SETB | | | | | MOV | LEDRAM1,#0FFH | ;Turn on all of LEDs | | | VOM | LEDRAM2,#0FFH | | | | | | | | | VOM | SP,#Stack | ;Load stack | | | VOM | RTL, #RTNL | ;Load timer for 5mSec. | | | VOM | RTH, #RTNH | | | | MOV | TL, #RTNL | ;Setup timer | | | VOM | TH, #RTNH | parameter of the control cont | | | VOM | TCON, #BIT4+BIT2 | | | | VOM | IE, #BIT7+BIT3+B | IT1+BIT0 ; Enable interrupt for | | | | | ; Copy_key inputTimer0 & TimerI | | | ACALL | Beep | ;Init. beep | | | VOM | LEDRAM1,#0B0H | ;Turn off all of LEDs except wait_led | | | VOM | LEDRAM2,#030H | | | ; | | | | | Wait: | JNB | GO,\$ | ;Wait for Copy_key released | | | CLR | BGo | ;Clear flag of Copy_key | | | JNB | BGo,\$ | ;Wait for Copy_key input | | | | | | | | NOV | LEDRAM1,#30H | ;Clear all of LEDs | | | MOV | LEDRAM2,#30H | | | | | | | | | CLR | POWER | ;switch power supply for eeprom & bus | | | ACALL | Delay30 | ;Delay 30 mSEC. | | | | | | ``` RcvDat,#08H XmtDat,#08H MOV ;Load pointer for receive buffer address ;Load pointer for tranx buffer address MOV MOV R7,#128 ;Load ram location counter for PCF8582 B8582,$+5 JB ; If option for PCF8582 then skip MOV R7,#64 ;Load ram location counter for PCF8581 MOV SubAdr,#0 ;Load eeprom subaddress BComp, PROG03 TNB ; If option for eeprom compare only EEPROM Programming Main Loop PROG01: ACALL ENSRROM ;Enable source eeprom MOV SlvAdr, #SourceAdr; Load source eeprom slave address MOV ;Load eeprom group counter PROG01A: MOV ByteCnt,#2 ;Load byte_counter to read source data ACALL RcvData ;Read data from source eeprom ;If need retry then try again JB Retry, PROG01A JNB ; If have ack. then continu NoAck, PROG02 AJMP Error ;Else Source eeprom no ack. & goto error PROG02: MOV R5,#4 ;Load eeprom number counter within group MOV A,R6 CJNE A, #1, $+5 ; If in last eeprom group MOV R5,#2 ; then load eeprom number counter with 2 ACALL ENTGROM ; Enable target eeprom group SlvAdr, #TargetAdr; Load target eeprom slave address MOV PROG02A: ACALL RdFlag ;Read target eeprom status JC PROG02C ; If the target eeprom was error ; then skip it PROG02B: VOM ByteCnt, #2 ;Else load byte_counter for data write ACALL SendData write data to target eeprom JB Retry, PROG02B ; If need retry then try again JNB NoAck, PROG02C ; If have ack. then continu ACALL SetFlag ; Else set error flag for the target eeprom PROG02C: INC SlvAdr ; Inc. slave address for next target eeprom TNC SlvAdr DJNZ R5, PROG02A ; If one group eeprom copy not finished ; then go back to copy next target eeprom DJNZ R6,PROG02 ; If three group eeprom copy not finished ; then go back to copy next group eeprom ACALL Delay30 ;Delay 70 mSEC INC SubAdr ; Inc. eeprom subaddress INC SubAdr ; for next 2 byte copy loop DJNZ R7,PROG01 ; If eeprom location copy not finished ; then go back for 2 byte copy loop MOV SubAdr, #0 ;Load eeprom subaddress for verification MOV R7,#16 ;Load ram location counter for PCF8582 B8582, PROG03 JTR ;If option for PCF8582 then skip MOV R7,#8 ;Else load ram location counter with 8 ``` AN453 | ;<br>; | EEPROM | Programming Main | | |-----------|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ; | | | | | • | | | | | PROG03: | ACALL | ENSRROM | ;Enable source eeprom | | | MOV | | dr;Load source eeprom slave address | | | MOV | R6,#3 | ;Load eeprom group counter | | | MOV | RcvDat,#08H | ;Load pointer for receive buffer address | | | | | | | PROG03A: | MOV | ByteCnt, #16 | ;Load byte_counter to read source data | | PROGUSA. | ACALL | RcvData | Read data from source eeprom | | | JB | Retry, PROG03A | ;If need retry then try again | | | JB | NoAck, Error | ; If no ack. then go to error | | | OB , | Horicit/ Elitor | | | | MOV | RcvDat,#18H | ;Load pointer for trank buffer address | | | MOV | RCVDac, #1011 | A STATE OF STATE AND ASSESSED TO STATE OF | | PROG04: | MOV | R5,#4 | ;Load eeprom number counter within group | | 11.00011 | MOV | A,R6 | | | | CJNE | A,#1,\$+5 | ;If in last eeprom group | | | MOV | R5,#2 | ; then load eeprom number counter with 2 | | | ACALL | ENTGROM | ;Enable target eeprom group | | | MOV | | dr;Load target eeprom slave address | | | | | | | PROG04A: | ACALL | RdFlag | ;Read target eeprom status | | FROGUAN. | JC | PROG04C | ;If the target eeprom was error | | | oc. | TROGUTE | ; then skip it | | PROG04B: | MOV | ByteCnt, #16 | ;Else load byte_counter to read data from | | PROGUED. | ACALL | RcvData | ; target eeprom for verification | | | JB | Retry, PROG04B | | | | JB | NoAck, PROG04C | ; If no ack. then go to set error flag | | | ACALL | Compare | ;Compare the data read from source and | | | JZ | PROG04D | ; target eeprom | | | 0.2 | 11100012 | ;If the data is ok then continu | | PROG04C: | ACALL | SetFlag | ;Else set error flag | | 11.000101 | | 2001 - 0.3 | , | | DDOGGAD. | INC | SlvAdr | ;Inc. slave address for next target eeprom | | PROG04D: | INC | SlvAdr | ; Inc. stave address for next target eeprom | | | DJNZ | R5, PROG04A | ;If one group eeprom verify not finished | | | DONZ | NJ, PROGUA | ; then go back to verify next eeprom | | | DJNZ | R6,PROG04 | ;If three group eeprom verify not finished | | | DONE | NO,INOGO4 | ; then go back to verify next group eeprom | | | MOV | A, SubAdr | , ones go water to the second group to be | | | ADD | A, #16 | ;incr. eeprom subaddress for next 16 byte | | | MOV | SubAdr, A | ; verification loop | | | DJNZ | R7, PROG03 | ;If eeprom location verify not finished | | | | , | ; then go back for 16 byte verify loop | | | MOV | A, LEDRAM1 | ;Test if there is any target eeprom error | | | ANL | A, #BIT6+BIT3+BI | | | | JNZ | Error1 | ;go to turn on Error_LED | | | MOV | A, LEDRAM2 | | | | ANL | A, #BIT6+BIT3+BI | IT2+BIT1+BIT0 | | | JNZ | Error1 | ;go to turn Error_LED | | | | | | | PROG05: | CLR | GROUP3 | ;Disable all of eeprom group | | | SETB | POWER | ;Switch power supply off for eeprom & bus | | | SETB | BWAIT | ;Turn on Wait_LED | | | ACALL | | ;Beep for copy completement | | | AJMP | | ;Go to wait for next Copy input | | ; | | | <del></del> | | | | | | | Error: | MOV | LEDRAM1,#30H | ;Turn off all of LED | | | MOV | LEDRAM2,#30H | | | Error1: | SETB | BERROR | ;Turn on Error_LED | | | AJMP | PROG05 | | | ; | | | | | | | | | ``` Compare Code Between Source and Target EEPROM ;Compare 16 bytes between 08h-17h and 18h-27h ;Output: A = 0 SAME A <> 0 NOT SAME Compare: MOV R0,#07H ;Load pointer for RAM block compare MOV R1,#17H MOV R2,#16 ;Load byte counter for compare Compare1: INC R0 TNC R1 MOV A, @RO XRL A,@R1 JNZ CompExit ;If two byte not same then exit with A<>0 DJNZ R2, Compare1 ; If compare loop finished then exit with ; (A) = 0 CompExit: RET Buzzer driver Beep: SETB BBZ ;Set buzzer output flag MOV R0,#6 ;Load counter MOV R1,#0FFH Beep0: Beep1: MOV R2,#14 CPL BBZ ;Compl. buzzer output flag MOV C,BBZ MOV BZ,C ;output to drive buzzer MOV BEP1,C MOV BEP2,C Beep2: ACALL SDelay DJNZ R2,Beep2 R1,Beep1 DJNZ DJNZ R0, Beep0 SETB BEP1 SETB BEP2 SETB RET Enable the Source EEPROM ENSRROM: CLR GROUP1 ;Disable eeprom group1 and group2 CLR GROUP2 SETB GROUP3 ;Enable eeprom group3 for source eeprom RET ``` AN453 ``` Enable the Target EEPROM ENTGROM: CLR GROUP1 ;Disable all of eeprom group first CLR GROUP2 GROUP3 CLR VOM A,R6 A,#01,$+7 ; If target eeprom not in group3 then skip CJNE ;Else enable eeprom group3 SETB GROUP3 AJMP ENTGROM1 ; If target eeprom not in group2 then skip CJNE A,#02,$+7 ;Else enable eeprom group2 SETB GROUP2 AJMP ENTGROM1 ;Enable eeprom group1 SETB GROUP1 ENTGROM1: RET Time Delay 30mSEC ____ Delay30: VOM RO,#60 Dly30A: VOM R1,#0FFH DJNZ R1,$ DJNZ RO, DLY30A RET _____ Read EEPROM Status RdFlag: MOV A,#3 ; Eeprom number = ; ((eeprom group number)-1) * 4 CLR C A,R6 + (eeprom number in group) SUBB ;((eeprom group number)-1) = VOM B,A MOV A,#4 (3-(eeprom group counter)) MUL AB ; ((eeprom group number)-1) * 4 MOV R2,A ;Backup VOM A,R6 A,#01,$+7 ; If it is not eeprom group 3 CJNE MOV A,#03 ;Else (eeprom number in group) = AJMP ; (3 - (eeprom number counter in group)) $+4 VOM A,#05 ;It is not eeprom group 3, then CLR С (eeprom number in group) = ; (5 - (eeprom number counter in group)) SUBB A,R5 ADD A,R2 ;Get eeprom number from 1 to 10 DEC ;Get address offset of eeprom status table RL Α RL MOV DPTR, #ReadTable ; Load status table address ;Jump to read eeprom status flag JMP @A+DPTR ReadTable: VOM C,BLED01 ;Read eeprom_1 status in carry AJMP TableExit C,BLED02 ;Read eeprom_2 status in carry VOM TableExit AJMP ;Read eeprom_3 status in carry VOM C,BLED03 A.TMP TableExit C,BLED04 ;Read eeprom_4 status in carry VOM TableExit AJMP C,BLED05 ;Read eeprom_5 status in carry VOM AJMP TableExit ``` AN453 ``` VOM C,BLED06 ;Read eeprom_6 status in carry AJMP TableExit VOM C,BLED07 ;Read eeprom_7 status in carry TableExit AJMP VOM C, BLED08 ;Read eeprom_8 status in carry AJMP TableExit MOV C,BLED09 ;Read eeprom_9 status in carry AJMP TableExit. MOV C,BLED10 ;Read eeprom_10 status in carry TableExit: RET Set EEPROM Status MOV SetFlag: A,#3 ;Eeprom number = CLR С ; ((eeprom group number)-1) * 4 SUBB A,R6 + (eeprom number in group) MOV B,A ;((eeprom group number)-1) = MOV A,#4 ; (3-(eeprom group counter)) MUL AB ;((eeprom group number)-1) * 4 MOV R2,A ;Backup MOV A,R6 ;If it is not eeprom group 3 CJNE A,#01,$+7 then skip MOV A,#03 ;Else (eeprom number in group) = AJMP $+4 ; (3 - (eeprom number counter in group)) VOM A,#05 ;It is not eeprom group 3, then CLR C (eeprom number in group) = SUBB A,R5 ; (5 - (eeprom number counter in group)) ADD A,R2 ;Get eeprom number from 1 to 10 DEC Α ;Get address offset of eeprom status table RL RL MOV DPTR, #SetTable ;Load status table address JMP @A+DPTR ;Jump to set eeprom status flag SetTable: SETB BLED01 ;Set LED_1 error flag AJMP TableExit SETB BLED02 ;Set LED_2 error flag TableExit A.TMP SETB BLED03 ;Set LED_3 error flag AJMP TableExit SETB BLED04 ;Set LED_4 error flag AJMP TableExit SETB BLED05 ;Set LED_5 error flag AJMP TableExit SETB BLED06 ;Set LED_6 error flag AJMP TableExit SETB BLED07 ;Set LED_7 error flag AJMP TableExit SETB BLED08 ;Set LED_8 error flag AJMP TableExit SETB BLED09 ;Set LED_9 error flag AJMP TableExit SETB BLED10 ;Set LED_10 error flag AJMP TableExit ``` END # Using the 87C751 microcontroller to gang program PCF8582/PCF8581 EEPROMs **AN454** #### INTRODUCTION The most interesting feature of the Philips 83C576, and the principal subject of this application note is its Universal Peripheral Interface (UPI). The UPI is a microprocessor slave interface which allows the '576 to communicate with a microprocessor or microcontroller host with minimal support logic. The UPI acts as a "bus gasket" between the 8051 core inside the '576 and the host. Commands and Data can easily be exchanged over this interface. Along with the hardware interface, a simple, effective bidirectional software protocol can be implemented for reliable data transfer. Each device can pace the exchange of data using a double bi-directional data register implemented as part of the UPI inside the '576. As part of the UPI definition, hardware flow control is supported so that both the host and 8051 core can each establish whether the other has written or read any data to the UPI. This flow control scheme is the heart of a synchronous interface that is independent of the performance of the host or 8051 core. The UPI is ideal for the PC environment and provides an almost seamless interface to the PC host via the ISA bus. This application note demonstrates in both hardware and software terms how to interface the '576 to a PC host. The UPI interface occupies two locations in the memory or IO space of each device. The first location is the Data register and the second is the Status register. The Data register is simply a pair of registers one directed to the host and the other directed to the 8051 core. This allows both the host and 8051 core to write to the data register simultaneously without effecting each-others data. The write cycle events are recorded as 'buffer flags' (IBF and OBE) in the Status register. One further unique feature of this interface is the concept of 'Commands and Data' in that any data written to the Status register address is directed to the Data register and a flag is set in the Status register recording this cycle as a Command. This flag is known as the 'AF' flag and indicates that a write cycle has been performed on the Status register. From a software perspective the host device is the 'master' of the UPI. Even though from a hardware sense, each device can pace the cycles, the provision of a single AF flag precludes the implementation of a multi-master protocol. This limitation, however, is not severe, in that this provides a simple scheme for exchanging data between the devices. This interface provides the mechanisms for many protocol schemes, the most effective one is used in PCs over the keyboard interface and operates as follows: #### **HOST (Master)** SLAVE ('576 core) Write a command to the Status register. AF flag set, the byte in the data register is a Command Poll the IBF flag in the Status register; wait for it to be 0. Read the command. Write the Information byte to the Data register. AF=0, read the information byte from the Data register; Execute the Command. Poll OBE, wait for it to be cleared in the Status register; this means that a response is available in the data register. Write a Response byte to the data register. Read the Response byte. #### DESCRIPTION The purpose of this Application Note is to demonstrate the use of the '576 in a PC environment. This example shows the use of a '576 as a peripheral to the PC/AT. The example shows the implementation of a data acquisition card with digital IO and analog IO. Some software is described to show how to exchange data and commands between the PC and the '576. In this example, the PC is the host of the transfers and the '576 is the slave. An example circuit is also described which details the electrical interface to the PC/AT ISA bus. Figure 1 shows the basic configuration of the acquisition system. Figure 1. Block Diagram #### **UPI DEFINITION** The Universal Peripheral Interface (UPI) functions as a microprocessor slave interface. This allows the '576 to interface directly to a microprocessor bus as a slave or peripheral device. The UPI is an 8-bit bidirectional data register, P0, with an associated status register, UCS. The data buffer is comprised of two registers; the input register and, the output register. The input register can be written by the host and read by the '576. The output register can be written by the '576 and read by the host. The status register may be read or written by the '576 core but may only be read by the host. The Status register bits can also be affected by hardware events, for example, a host write cycle to the data register will set the IBF flag. The host control interface for these registers is comprised of four signals, –RD, –WR, an address line A0, and a chip select –CS. Data transfer is directed to the UPI as shown below: | -cs | A0 | -RD | -WR | CONDITION | |-----|----|-----|-----|---------------------------------| | 0 | 0 | 0 | 1 | Read Output Data Register | | 0 | 1. | 0 | 1 | Read Status Register | | 0 | 0 | 1 | 0 | Write Input Data Register, AF=0 | | 0 | 1 | 1 | 0 | Write Input Data Register, AF=1 | | 1 1 | х | х | X | Disable IO | Write cycles to the data register with A0 = 1 cause the AF flag to be set in the status register. These cycles are generally interpreted as commands. Write cycles to the data register with A0 = 0 cause the AF flag to be cleared in the status register. These cycles are usually interpreted as data. The status register has 4 control bits and 4 user defined status bits. They are defined as follows: #### ucs \* NOTE: This flag is OBE when read by the MCU, but is inverted or OBF (Output Buffer Full) when read by an external host. #### **General Handshaking Protocol** Host write cycles with A0 set are directed to the Input Data Register. The '576 can distinguish the cycles by monitoring the AF flag (Address Flag) in the status register. Figure 2. Internal Structure of the UPI Registers Philips Semiconductors Application note ## Interfacing the 83C576/87C576 to the ISA bus AN454 #### ISA BUS INTERFACE The data acquisition system is comprised of the '576 microcontroller and an address decoder. The '576 provides an almost seamless interface to the PC/AT IO channel. The interface to the PC is known as the ISA (Industry Standard Architecture) bus. This bus is an asynchronous, command driven bus. Most notebook and PDA chipsets provide programmable or fixed address decoders assigned to an output pin. This pin is used to control the -CS input of the '576 thus providing a completely seamless interface to the ISA bus. #### **Address Path** In this application the '576 is interfaced as an IO device. The IO space on a PC is 0 to 03FFH (1Kbytes), therefore SA0 to SA9 must be decoded to locate the '576 in a single region. SA0, however, is used to select between the Data and Status registers, thus the '576 occupies two locations in IO space. For the acquisition card we selected 0300H for the Data register and 0301H for the Status register. 300H and 301H have been chosen because they are assigned to a "prototyping area" in the PC ISA IO space map. The address decoder must reject the address during DMA cycles. For this purpose, AEN is used in the decoder and qualified for its low, inactive state (AEN, when active indicates that the current cycle is a DMA cycle). Output Y0 of U2 is asserted (low) when SA5 to SA7 are low, SA8 is high and AEN is low. U3 further decodes the address and output Y0 is asserted (low) when Y0 of U2 is low together with SA1 to SA4 low and SA9 high. Output Y0 of U3 is fed to the -CS input of the '576, it is asserted (low) when the address is 300H with AEN low or 301H with AEN low. #### **Data Path** The '576 interfaces to the least significant 8 bits of the data bus, SD0 to SD7. When the '576 is configured in UPI mode, PORT0 is configured as push–pull outputs for host read cycles. ISA requires 24mA $I_{\rm OL}$ for this interface. The '576 can only handle 15mA. The 24mA requirement goes back to the XT–TTL days and with current CMOS motherboards 12mA is probably sufficient with a fully loaded system. #### Interrupt An interrupt is employed to completely demonstrate the integration of the '576 to the PC. The first free interrupt is IRQ10. For this reason alone, we need to connect to the extended AT ISA slot where this interrupt line is available. Interrupts on PCs are edge sensitive, sometimes shared and are usually pulled—up on the motherboard just to make life more complicated. If we want to generate an interrupt, port pin P2.3 must be driven low then high. The 8259 interrupt controller in the PC will see the interrupt on the rising edge. Once the host acknowledges the interrupt by say, reading the Data register (detected by the assertion of OBE) the '576 must drive P2.3 high, returning IRQ10 to a high impedance state. #### **Timina** Another aspect of the design is to consider the timing implications of the UPI. The diagrams below show the relationships of the control, address and data signals. | SYMBOL | PARAMETER | LIMITS | | |-----------------|---------------------|------------------------------------|--| | t <sub>AS</sub> | Address Setup time | 21ns MIN | | | t <sub>PW</sub> | Command pulse width | 600ns MIN<br>(assumes 8.33MHz bus) | | | t <sub>DS</sub> | Data setup time | 15ns MIN | | | t <sub>DH</sub> | Data hold time | 15ns MIN | | | t <sub>CR</sub> | Cycle recovery time | 55ns MIN | | The address setup time is lengthened by the two 3 to 8 line decoders, U2 and U3. The ISA worst case is 9ns, we are adding 2 further delays of 6ns giving 21ns of address setup. If the ISA bus is clocked at a higher rate as in some PDAs and some notebooks, the Command pulse width will be shortened. The ISA bus can be clocked as high as 11.1MHz, yielding a minimum command pulse width of 450ns. Figure 3. ISA Cycle IO Read Timing Figure 4. ISA Cycle IO Write Timing #### SOFTWARE The example below shows a typical protocol employed here to exchange data between the PC and the '576. The protocol that we are employing is only a subset of what can be achieved with this Command / Data, two byte protocol. To complete a transaction, the PC sends two bytes, a Command and Information byte, then the '576 returns two bytes; a response and information byte. Sometimes the information bytes will be meaningless; that's okay, as long as we stick to the protocol. #### COMMANDS | | Command | Information | | |-------|--------------------------------|-----------------------------|--------------| | 01H | Get Analog Channel | Channel | [0, 1, 2, 3] | | 02H | Get Digital Byte | NULL | | | 03H | Put Digital Byte | Data Byte | | | 04H | Increase PWM | Channel | [0, 1] | | RESPO | NSES | | | | | Response | Information | | | 01H | Get Analog Channel<br>Complete | M.S. 8 bits of A conversion | DC | | 02H | Get Digital Byte<br>Complete | Data Byte | | | 03H | Put Digital Byte<br>Complete | NULL | | | 04H | Increase PWM<br>Complete | NULL | | #### **DRIVERS** #### **PC Driver** The PC must write a command. This is done by making an IO cycle to port 0301H. This sets the AF flag in the status register and causes an IBF interrupt in the '576. The PC can poll the status register to see when the IBF flag has cleared, this means that the '576 has read the Command in the Input Data Register. The PC then sends the Information byte; this is done in the same way except that the cycle is made to 300H. #### 576 Driver Communication from the '576 to the PC is established by driving the interrupt request line, IRQ10, high. The PC first reads the status register to check if the interrupt was from the '576 instead of some other external device. If the OBF flag is set, the PC knows that the data in the Output Data Register is valid. The PC then reads to Output Data Register which causes the OBF flag to become cleared. Once the '576 detects this read cycle, the interrupt line, P2.3, can be returned to its low state. The AF bit in the Status register indicates whether the data is a Response byte to a previous command (AF set) or an associated Information byte (AF cleared). AN454 ``` Code to demonstrate the use of the UPI to the '576 in an interrupt driven mode. Written in Microsoft C7.0 for PC AT #include <stdio.h> #include <stdlib.h> #include <string.h> #include <dos.h> #include <comio.h> #define UC unsigned char #define UL unsigned long #define UI unsigned int #define P8259A IMR 0 \times 21 /* ;interrupt mask register i/o address #define P8259B_IMR 0xa1 /* ;interrupt mask register i/o address #define EOI 0 \times 20 #define P8259A 0x20 #define P8259B 0xa0 #define ENABLE_IRQ10 ~0x04 #define ENABLE_IRQ2 \sim 0 \times 04 #define UPI_DATA_REG 0x300 #define UPI_STATUS_REG 0x301 #define IBF 0 \times 02 #define OBF 0 \times 0.1 unsigned char interrupt_received = 0; /* declare a variable to store the pointer of the current interrupt service routine */ void (_interrupt _far *old_int)(); /*Module put_byte(). put_byte() has two parameters; the address of the IO port (port) and the value to be written to the IO port (data). A dummy variable is declared for lint purposes, since the C function outp() returns an unsigned short. First put_byte() uses the C oupt() function to write the byte to the IO port then, put_byte() monitors the IBF flag in the status register to see if the '576 has read the byte. When the PC writes the byte to the input register, the '576 automatically sets the IBF flag. When the '576 core reads the input register, the IBF flag is automatically cleared. The while() loop breaks when the IBF is 0. The C function inp() is used to read the status register, the returned value is logically ANDed with the constant IBF (0x02) and the result is complemented and evaluated by the while() statement. \star/ void put_byte ( unsigned short port, unsigned char data) { unsigned short dummy; dummy = outp(port, UPI_DATA_REG); // send the byte while (~(inp(UPI_STATUS_REG) && IBF)); // check to see if '576 has read it } ``` AN454 ``` /*Module get_byte() get_byte() has 1 parameter and 1 return value. The parameter is used to pass the address of the IO port to read. The return value is used to pass back the contents of the read port as a byte. get_byte first waits for the byte to be written to the UPI port by the '576. This is achieved by monitoring the OBE flag in the status register. The C function inp() is used to read the contents of the status register. The returned word is masked (ANDed) with the constant OBF (0x01) and the negated result is evaluated by the while() statement. If the IBF flag is 0, the while loop continues to read and evaluate the status register, if the IBF flag is set the while loop breaks. When the while loop breaks, there must be something to read in the output data register, the C function inp() is used to read the input data register whose address is past in the variable 'port'. The result is cast as a byte and returned to the calling routine. */ unsigned char get_byte ( unsigned short port) { while (!(inp(UPI_STATUS_REG) && OBF)); // wait for the byte return ((byte)inp(port)); /*Module send_command() send command assembles a two byte message comprising of a command byte follwed by an information byte. If we direct the first byte to the address of the status register, it will appear in the output data register and the AF flag will automatically be set. The '576 will read the status register before the data register, the set AF flag will tag the data as a command. The information byte is directly written to the output data register, thus the AF flag will be cleared and the '576 will interpret the byte as information. */ void send_command ( unsigned char command, unsigned char information ) { put_byte(UPI_STATUS_REG, command); put_byte(UPI_DATA_REG, information); /* Module get_response() This module has no parameters and 1 return value. get_response strips out the information byte from a two-byte message from the '576. The first byte is always the echoed command and is discarded by assigning it to a dummy variable. The send byte is always the information and is read using the get_byte() function and returned to the calling function. */ unsigned char get_response ( void ) { unsigned char dummy; dummy = get_byte(UPI_DATA_REG); // get the response return(get_byte(UPI_DATA_REG)); // return the info byte } ``` AN454 ``` /* Module EnableIRQ10() This module enables the hardware interrupt, IRQ10 via the 8259 programmable interrupt controller (PIC) insude the PC. IRQ 10 is a cascaded interrupt driven by a sencond PIC attached to IRQ2 of the first. Therefore both PICs need to be unmasked. The C function disable() issues a CLI instruction to the processor disabling interrupts. The current value of the interrupt mask for PICA is read and ANDed with the mask cleared for IRQ2. The current value of the interrupt mask for PICB is read and ANDed with the mask cleared for IRQ10. The new masks are written to the PICs consecutively. Interrupts are re-enabled using the C function enable() which issues an STI instruction to the processor. */ EnableIRQ10 (void) { unsigned short mask; _disable(); mask = _inp(P8259A_IMR); mask &= ENABLE IRO2 (P8259A_IMR, mask); mask = _inp(P8259B_IMR); mask &= ENABLE_IRQ10; _outp (P8259B_IMR, mask); _enable(); } /* Module Irq10_isr() This module is the service routine for an IRQ10 interrupt. It simply sets a global flag which is monitored by the main loop and then issues a "non specific end-of-interrupt (EOI)" to each PIC. The EOI flags are written to reset the interrupt signal that the PICs assert to each other and the processor." void __cdecl __interrupt __far Irq10_isr(void) { interrupt_recieved = 1; _outp(P8259A,EOI); _outp(P8259B,EOI); ``` ``` void main(void) { printf("\n576 Interrupt Interface Utility\n"); /* save the pointer of the current interrupt service routine using the C function _dos_getvect() */ old_int = _dos_getvect(0x12); /* store the pointer of our interrupt service routine (Irq10_isr) using the C function _dos_setvect() */ _dos_setvect(0x12, Irq10_isr); /* clear the global flag */ interrupt_received = 0; /* unmask and enable interrupts */ EnableIRQ10(); 01 00 returned "); printf("\nGet Analog Channel /* send the command */ send_command(1,0); /* wait for an interrupt */ while (~interrupt_received); /* print the result on sdtio (the screen) */ printf("%02x",get_response()); /* clear the global interrupt flag */ interrupt_received = 0; printf("\nGet Digital Byte 02 00 returned "); send_command(2,0); while(~interrupt_received); printf("%02x",get_response()); interrupt_received = 0; 03 55 returned "); printf("\nPut Digital Byte send_command(3,0x55); while (~interrupt_received); printf("%02x",get_response()); interrupt_received = 0; 04 01 returned "); printf("\nSet PWM send_command(4,1); while (~interrupt_received); printf("%02x",get_response()); interrupt_received = 0; /* restore the old interrupt vector */ _dos_setvect(0x12, old_int); } ``` sfr sfr PWMP PWCON ## Interfacing the 83C576/87C576 to the ISA bus AN454 ``` /* Code to demonstrate the use of the UPI on the '576. Written in Franklin C for the '576. #include <reg51.h> // Constants #define UC unsigned char #define UI unsigned int // Special Function Registers sbit IRO = P2^3; sfr UCS = 0x86; sbit UE = UCS^3; sbit AF = UCS^2; sbit = UCS^1; sbit OBE = UCS^0; sfr ADC = 0xB1; sbit ADF = ADC^7; sbit ADCE = ADC^6; sbit AD8M = ADC^5; sbit AMOD1 = ADC^4; sbit AMOD0 = ADC^3; sbit ASCA2 = ADC^2: sbit ASCA1 = ADC^1; sbit ASCA0 = ADC^0; sfr ADC0H = 0xAA; sfr ADC1H = 0xAB; sfr ADC2H = 0xAC; sfr ADC3H = 0xAD; sfr ADC4H = 0xAE; sfr ADC5H = 0xAF; sfr PWM0 = 0xBE; PWM1 sfr = 0xBF; ``` 1994 Dec 21 570 $= 0 \times BD;$ = 0xBC; ``` /* Module get_analog_channel ``` This module initializes the ADC for mode 0 and 8 bit conversions. This module has 1 parameter and 1 return value. The channel to be converted is passed as an unsigned char parameter and converted to 3 single bit values. The converted values are set in the ADC control register. The conversion is started by setting the enable bit (ADCE). The conversion is monitored for completion by polling the ADF bit. The result from the selected channel is returned to the calling function using the switch() statement \*/ ``` get_analog_channel( UC channel ) { // Mode 0 AMOD0 = 0; AMOD1 = 0; AD8M = 1; // 8 bit mode ASCA2 = channel^2; ASCA1 = channel^1; ASCA0 = channel^0; ADCE = 1; // start conversion /* poll the ADF flag. This loop breaks when ADF = 1 */ while(~ADF); // wait for conversion to complete /* return the ADC value based on the selected channel */ switch (channel) { case 0: return(ADCOH); break; case 1: return (ADC1H); break; case 2: return(ADC2H); break: case 3: return(ADC3H); break; case 4: return(ADC4H); break; case 5: return(ADC5H); break; default: return(0xFF); break; } } ``` AN454 ``` /* Module get_digital_byte() This module has 1 parameter and 1 return value. The parameter is included for consistency with the other functions and has no meaning in this case. The return value is the combined result of reading 6 bits from P3 and 2 bits from P2. */ get_digital_byte (UC dummy) { // declare a temporary variable UC byte; // read P3 and strip the 2 M.S. bits byte = P3 \&\& 0x3f; // read P2, strip 6 M.S. bits, shift result 6 places left and OR with the temporary variable byte = ((P2 && 0x03) << 6); // return the result return (byte); /* Module put_digital_byte() This module take the byte, passed as a parameter, masks the unused bits of the ports and ORs the masked result with the current port values. */ put_digital_byte ( UC byte ) { // clear the current port value P3 &= 0xc0; // AND the parameter with a mask and OR the result with the cleared port value P3 |= (byte && 0x3f); P2 &= 0x3f; P2 = ((byte && 0xc0) >> 6); return(byte); } /* Module increase_pwm() This module increments the current PWM value of the selected channel. The channel is passed to this function as a parameter */ UC increase_pwm ( UC channel ) { // test the channel parameter if (channel == 0) // increase PWM0 PWM0++: else // increase PWM1 PWM1++; return(channel); } ``` 572 1994 Dec 21 ``` main () { // declare temporary variables for the command and information bytes UC command; UC information; // initialize the PWM controller PWMP = 0x80; PWCON = 0xFF; // do forever while(1) { // wait for a command from the PC ie, when the IBF flag is set while (~IBF); // wait for the command // read the command byte. This read clears the IBF automatically command = P0; // wait for the next byte from the PC // wait for the information while (~IBF); information = P0; // echo the command P0 = command; // wait for the PC to read it while (OBE); // parse the command and call the appropriate function, passing the information as a parameter switch (command) { case 1 : { P0 = get_analog_channel(information); break; } case 2: { P0 = get_digital_byte(information); break: case 3: { P0 = put_digital_byte(information); break; } case 4: { P0 = increase_pwm(information); break; default: { P0 = 0xFF; break; // wait for the PC to read the information. while (OBE); } } ``` ### **Philips Semiconductors** # **Section 8**Other 80C51 Application Notes & Articles Application Notes and Development Tools for 80C51 Microcontrollers ### CONTENTS | AN408 | 80C451 operation of port 6 | 577 | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | AN417 | 256k Centronics printer buffer using the 87C451 microcontroller | 588 | | AN418 | Counter/timer 2 of the 83C552 microcontroller | 601 | | AN420 | Using up to 5 external interrupts on 80C51 family microcontrollers | 608 | | AN424 | 8051 family warm boot determinations | 610 | | AN440 | RAM loader program for 80C51 family applications | 612 | | AN443 | IEEE Micro Mouse using the 87C751 microcontroller | 621 | | AN447 | Automatic baud rate detection for the 80C51 | 642 | | AN448 | Determining baud rates for 8051 UARTs and other UART issues | 645 | | ESG89001 | Electro magnetic compatibility and printed circuit board (PCB) constraints $% \left( \frac{1}{2}\right) =\frac{1}{2}\left( \frac{1}{2}\right) +\frac{1}{2}\left( +$ | 648 | | EIE/AN9100 | 1 Workbench EMC evaluation method | 667 | | EIE/AN9100 | 6 A/D conversion with P83CL410 PCF1252-x | 684 | | EIE/AN9100 | 9 Driver for 8xC851 E2PROM | 700 | | EIE/AN9200 | 1 Low RF-emission applications with a P83CE654 microcontroller | 715 | | EIE/AN9301 | 7 Using the analog-to-digital converter of the 8XC552 microcontroller | 727 | | Chips push ( | CAN bus into embedded world | 745 | | Add Text Ov | erlay to Any Video Display | 747 | **AN408** ### INTRODUCTION The features of the 80C451 are shared with the 80C51 or are conventional except for the operation of port 6. The flexibility of this port facilitates high-speed parallel data communications. This application note discusses the use of port 6 and is divided into the following sections: - 1. Port 6 as a processor bus interface. - 2. Using port 6 as a standard pseudo bidirectional I/O port. - 3. Implementation of parallel printer ports. This information applies to all versions of the part: 80C451, 83C451, and the 87C451. # PORT 6 AS A PROCESSOR BUS INTERFACE Port 6 allows use of the 80C451 as an element on a microprocessor type bus. The host processor could be a general purpose MPU or the data bus of a microcontroller like the 80C451 itself. This feature allows single or multiple 80C451 controllers to be used on a bus as flexible peripheral processing elements. Applications could include keyboard scanners, serial I/O controllers, servo controllers, etc. ### **OPERATION** On reset, port 6 is programmed correctly for use as a bus interface (see 2). This prevents the interface from disrupting data on the bus of the host processor during power-up. Software initialization of the CSR (Control Status Register) is not required. A dummy read of port 6 may be required to clear the IBF (Input Buffer Full) flag since it could be set by turn on transients on the bus of the host processor. On reset, the CSR of the 83C451 is programmed to allow the following: - AFLAG is an input controlling the port select function. If AFLAG is high, the contents of the CSR is output on port 6 when the port is read by the host. If AFLAG is low, then the contents of the output latch is output when port 6 is read by the host. - 2. BFLAG is an input controlling the port enable function. In this mode when BFLAG is high, the input latch and the output drivers are disabled and the flags are not affected by the IDS (Input Data Strobe) or ODS (Output Data Strobe) signals. When BFLAG is low, the port is enabled for reading and writing under the control of IDS and ODS pins. Figure 1 shows one possible example of an 80C451 on a memory bus. This arrangement allows the main processor to query port 6 for flag status without interrupting the 80C451. If the address decoder, shown in Figure 1, enables port 6 on the 80C451 when the address is 8000H or 8001H, and the address line A0 controls the port select feature, then the host processor can read and write to port 6 using address 8000H. Since the port select function is being controlled by the address line A0, the CSR contents can be read by the host processor at address 8001H. By testing the CSR contents in this way, the host processor can tell if new data has been written to the port 6 output latch since it last read the port or if the 80C451 has read the last byte that the host wrote to the port. Conversely, the 80C451 can poll the flags in its CSR to see if the host processor has written to or read from port 6 since the last time it serviced the port. If desired, an interrupt source for the 80C451 can be derived easily from the port enable source as shown by the dashed line in Figure 1. Figure 1. An 83C451 on a Microprocessor Memory Bus AN408 ### SOFTWARE EXAMPLES To write to port 6 on the bus shown in Figure 1, the host processor first reads the CSR contents at address 8001H, and tests the input buffer full flag (CSR bit 0). If the flag is clear, the host writes a byte to address 8000H. This loads the input buffer latch of port 6 and sets the input buffer full flag. Conversely, the 80C451 polls the IBF flag and reads a byte from port 6 when it finds the flag set. The flag is automatically reset when this internal read occurs. ### 80C451 ROUTINE TO READ ONE BYTE FROM HOST VIA PORT 6 RCVR: JNB CSR.0,RCVR MOV A,P6 :TEST IBF FLAG RET WHEN FLAG IS SET READ BYTE ### 80C451 ROUTINE TO WRITE ONE BYTE TO THE 83C451 PORT 6 If the host processor is an 80C51, the following routine will write a byte of data to the 80C451. The data involved is passed to the routine through register 1. XMIT: MOV DPTR.8001H TEST: MOVX A.@DPTR JB ACC.0,TEST ;READ THE CSR ;TEST IBF FLAG MOV DPTR,8000H MOV A,R1 MOVX @DPTR,A :WRITE DATA TO THE 451 RET ### 80C451 ROUTINE TO WRITE ONE BYTE TO HOST VIA PORT 6 Routines for data transfer in the opposite direction are similar to the above two. The 80C451 version is given below. XMIT: JB CSR.1,XMIT MOV P6,A :TEST OBF FLAG ;WRITE DATA RET | ١ | CSR 7 | CSR 6 | CSR 5 | CSR 4 | CSR 3 | CSR 2 | CSR 1 | CSR 0 | |---|-------|-------|-------|-------|-------|-------|-------|-------| | | MB1 | мво | MA1 | MAO | OBFC | IDSM | OBF | IBF | | | 1 | 1 | 1 | 1 | 1 | 1 | | , , | SU00333 Figure 2. CSR Programmed to Allow Port 6 as a Bus Interface **AN408** # USING PORT 6 AS A STANDARD QUASI-BIDIRECTIONAL I/O PORT To use port 6 as a common I/O port, all of the control pins are tied to ground (see Figure 3). On hardware reset, bits 2 - 7 in the CSR are set to one. Port operation and electrical characteristics become identical to port 1 on the 80C51 and the 80C451 ports 1, 4, and 5. No software initialization is required. If desired, AFLAG and BFLAG can be used as outputs while port 6 is operating as a standard quasi-bidirectional I/O port (see Figure 4). In this case, only IDS and ODS are tied to ground and the CSR is initialized to allow operation of AFLAG and BFLAG as simple outputs (see Figure 5). Figure 3. Standard I/O Port on Reset Figure 4. Standard I/O Port on Reset with AFLAG and BFLAG as Outputs | | | | | | <u> </u> | | | |-------|-------|-------|-------|-------|----------|-------|-------| | 1 | × | 0 | х | x | 1 | 100 | | | MB1 | мво | MA1 | MAO | OBFC | IDSM | OBF | IBF | | CSR 7 | CSR 6 | CSR 5 | CSR 4 | CSR 3 | CSR 2 | CSR 1 | CSR 0 | Figure 5. CSR Programmed to Allow AFLAG and BFLAG to Operate as Outputs and Port 6 as a Standard I/O Port | | DAT | A TRANSFER SIGNAL PINS | 3 | |----|---------|--------------------------|--------| | | Pin No. | Groung Return<br>Pin No. | Signal | | | . 1 | 19 | STROBE | | | 2 | 20 | DATA 1 | | | 3 | 21 | DATA 2 | | | 4 | 22 | DATA 3 | | *. | 5 | 23 | DATA 4 | | | 6 | 24 | DATA 5 | | | 7 | 25 | DATA 6 | | | 8 | 26 | DATA 7 | | | 9 | 27 | DATA 8 | | | 10 | 28 | ACKNLG | | | 11 | 29 | BUSY | | TYPICAL AUXILIARY PIN FUNCTIONS | | | | | | | |---------------------------------|----------------|--|--|--|--|--| | Pin No. | Signal | | | | | | | 12 | PAPER OUT | | | | | | | 14 | AUTO LINE FEED | | | | | | | 16 | LOGIC GROUND | | | | | | | 17 | CHASSIS GND | | | | | | | 30 | GROUND RETURN | | | | | | | 31 | RESET PRINTER | | | | | | | 32 | ERROR | | | | | | | 33 | GROUND RETURN | | | | | | | 36 | SLCTIN | | | | | | SU00337 SU00336 Figure 6. Parallel Printer Interface Pin Functions Philips Semiconductors Application note ### 80C451 operation of port 6 AN408 # IMPLEMENTATION OF PARALLEL PRINTER PORTS USING PORT 6 The 80C451 is an excellent choice for a printer controller. The 80C451 has the facilities to permit all of the intelligent features of a common printer to be handled by a single chip: - The features of port 6 allow a parallel printer port to be designed with only line driving and receiving chips required as additional hardware. - The onboard UART allows RS232 interfacing with only level shifting chips added - The 8-bit parallel ports 0 to 6 are ample to drive onboard control functions, even when ports are used for external memory access, interrupts, and other functions. - The RAM addressing ability of ports 0 and 2 can be used to address up to 64k bytes of a hardware buffer/spooler. AFLAG and BFLAG as simple outputs (see Figure 5). - The 64k byte ROM addressing capability allows space for the most sophisticated software. In addition, either end of a parallel interface can be implemented using port 6, and the interfaces can be interrupt driven or polled in either case. #### THE INTERFACE Data transfer on a parallel printer interface occurs across eleven signal lines. The other conductors on the standard plug are used as ground returns or for auxiliary functions (see Figure 6). Only the data transfer signals will be considered. ### The Data Transfer Format The parallel printer interfaces are far more standardized in features than their serial counterpart. However, at least three significant variations exist in handshake style in printers using generic parallel interfaces. This fact influences the design of both port hardware and software. A good transmitter should be able to drive devices with all three styles of handshakes, and a good receiver should generate the handshake most likely compatible with any transmitter. ### The Variations Type 1—Figure 7 shows a common style of handshake and is the style that will be implemented in the receiver examples. A busy signal and an acknowledge strobe pulse are generated for every byte received. Type 2—Another style of handshake generates a busy signal only when the printer will not be able to accept more data for a relatively long time. Acknowledge pulses are created after every byte received. When the busy signal is generated after a byte is received, the associated acknowledge pulse does not occur until after the busy signal returns to logic zero (see Figure 7). Type 3—A third handshake style does not generate acknowledge pulses, but a busy signal is produced after every byte is received. # PARALLEL PRINTER INTERFACES USING POLLING ### **Transmitter Operation** This application illustrates the flexibility of the port 6 logic in solving an applications problem. We need to be able to handle all types of acknowledge signals that might be received by the transmitter. We will use the ODS pin and output buffer full flag logic to record the receipt of the acknowledge pulse (see Figure 8), but not all parallel receivers generate acknowledge pulses. We could poll the busy signal line, but not all receivers generate busy signals for each byte received; so lack of a busy signal does not imply that we can send another byte. We can, however, expect an acknowledge pulse very shortly after the end of a busy signal if one is going to arrive at all. So we can send a new data byte after having received either a positive transition on the acknowledge line, or shortly after receiving a negative edge on the busy line. The CSR is programmed to the output only mode. In this mode, the ODS pin does not control the output drivers but only the output buffer full flag. The flag serves to record the positive transition of the acknowledge signal. The input latch is not used, but the IDS pin is used to set the input buffer full flag. This is used to record the negative transition at the end of the busy signal. Dummy reads by the 80C451 of port 6 will be used to clear the flag. In this example, the AFLAG mode is set only to place the port in the output only mode. The AFLAG pin is not actually used (see Figure 10). The transmitter's CSR (control status register) is programmed to the following mode (see Figure 9): - CSR bit 6 controls the BFLAG output and therefore the strobe line. - The OBF (output buffer full) flag controls the AFLAG output. - The OBF is cleared on the positive edge of the ODS input. - The IBF flag is cleared on the negative edge of the IDS strobe. #### NOTE: With this combination of modes set, port 6 is in the output only mode. **AN408** Figure 7. Parallel Printer Interface Signals Figure 8. Interconnection for a Parallel Interface Using Polling Figure 9. CSR Programmed for Polled Transmitter Operation ### **AN408** ### **Receiver Operation** In receiver operation, the IDS input is used to latch in the data transmitted on receipt of the strobe pulse. The receiver's CSR is programmed to allow the following (see Figure 11): - The input buffer full flag is output through the BFLAG pin and is used as the busy signal to the transmitter. - 2. The IBF flag is set and data is latched on the positive edge of IDS. - Writing to the CSR bit 4 controls the AFLAG output and therefore the acknowledge line. Figure 10. Flow Chart of Polled Parallel Transmitter Operation | CSR 7 | CSR 6 | CSR 5 | CSR 4 | CSR 3 | CSR 2 | CSR 1 | CSR 0 | 1 | |-------|-------|-----------------|-------|-------|-------|-------|-------|---------| | | | | | | | | | | | MB1 | MB0 | MA1 | MAO | OBFC | IDSM | OBF | IBF | | | 1 | 0 | 0 | 1 | 1 | 0 | | | | | | | enderge in to a | | | | | | SU00342 | Figure 11. CSR Programmed for Polled Parallel Receiver Operation **AN408** Figure 12. Flow Chart of Polled Parallel Receiver Operation ### **SOFTWARE EXAMPLES** This polled parallel transmit routine outputs one byte passed to it in the accumulator. | P_INIT: | MOV CSR,#064H | ;INITIALIZE PORT 6 OPERATING MODE | |---------|----------------|-----------------------------------| | P_OUT: | JB P5.0 | ;WAIT IF BUSY SIGNAL IS HIGH | | | MOV P6,ACC | ;OUTPUT DATA | | | MOV R1,P6 | ;DUMMY READ TO CLEAR IBF FLAG | | | MOV R1,#02H | ;INITIALIZE DELAY COUNTER | | | CLEAR CSR.6 | ;START STROBE PULSE | | | DJNZ R1,\$ | ;TIME 6 MICROSECOND STROBE PULSE | | | SETB CSR.6 | ;END STROBE PULSE | | WAIT: | JNB CSR.1,OUT | ;EXIT IF ACKNOWLEDGE RCV'D | | | JNB CSR.0,WAIT | ;EXIT IF NEGATIVE BUSY EDGE RCV'D | This polled parallel receive routine places one byte in the accumulator each time it is called. | P_INIT: | MOV CSR,#09CH | ;INITIALIZE PORT 6 OPERATING MODE | |---------|---------------|-----------------------------------| | | MOV R7,P6 | ;DUMMY READ TO CLEAR IBF FLAG | | P_IN | JNB CSR.0 | ;INPUT BUFFER LATCH FULL? | | | CLR CSR.4 | ;BEGIN ACKNOWLEDGE PULSE | | | MOV R7,#02H | ;INITIALIZE DELAY COUNTER | | | DJNZ R7,\$ | ;TIME ACKNOWLEDGE PULSE | | | MOV A,P6 | ;READ BYTE - CLEAR BUSY SIGNAL | | | MOV R7,#02H | ;INITIALIZE DELAY COUNTER | | | DJNZ R7,\$ | :TIME ACKNOWLEDGE PULSE | | | SETB CSR.4 | END ACKNOWLEDGE PULSE | | | RET | | **AN408** # INTERRUPT DRIVEN PARALLEL PRINTER INTERFACE (See Figure 13) ### **Transmitter Operation** The transmitter's CSR (control status register) is programmed to the following mode (see Figure 14): - CSR bit 6 controls the BFLAG output and therefore the strobe line. - The OBF (output buffer full) flag controls the AFLAG output. - 3. The OBF is cleared on the positive edge of the ODS (output data strobe) input. - The IBF flag is set on the negative edge of the IDS (input data strobe) pin. #### NOTE: With this combination of AFLAG and BFLAG modes set, port 6 is in the output only mode. The output drivers are always enabled and the ODS input is only used to clear the OBF flag. INTO is programmed to be negative edge sensitive and is connected to the OBF flag through the AFLAG pin. The OBF is cleared on the positive edge of ODS. The net result is that INTO is triggered on the end of the ACK pulse (a positive edge). This signals the transmitter that another byte may be transmitted. The transmitting 83C451 is free to do other tasks prior to this interrupt. In this routine, Figure 15, the main program establishes a buffer in data memory ended by an ASCII end of text character. To begin outputting the buffer, the routine PSEND is called. The rest of the buffer is emptied by the interrupt vectors to PSEND1. For printers which generate acknowledge pulses, output rates of 25k transfers per second are achieved. Timer generated interrupts are used to periodically return program execution to the routine to service non-acknowledging printers and to provide a timeout feature. Non-acknowledging printers are serviced at a rate of about 2.5k transfers per second. This maximum rate may be varied by adjusting the timer reload value. As written, the time out procedure attempts to retransmit a byte when the printer has not acknowledged for an excessively long time. ### **Receiver Operation** In receiver operation, the IDS input is used to latch in the data transmitted on receipt of the strobe pulse. The receiver's CSR is programmed to allow the following (see Figure 16): - The input buffer full flag is output through the BFLAG pin and is used as the busy signal to the transmitter. The IBF flag is set and data is latched on the positive edge of IDS. - Writing to the CSR bit 4 controls the AFLAG output and therefore the acknowledge line. The receiver is interrupted on the negative edge of the data strobe. Data is latched in on the positive edge of the strobe pulse (see Figure 17). Since the strobe pulse is normally very short, there is little time lost between receiving the interrupt and having valid data in the input latch. The receiver is free to do other tasks prior to receiving the INTO interrupt. Figure 13. Interrupt Driven Parallel Interfaces Using 80C451 Controllers **AN408** | | | | | | | | | - | | |-------|-------|-------|-------|-------|-------|-------|-------|---|---------| | CSR 7 | CSR 6 | CSR 5 | CSR 4 | CSR 3 | CSR 2 | CSR 1 | CSR 0 | | | | → MB1 | мво | MA1 | MAO | OBFC | IDSM | OBF | IBF | | | | 0 | 1 | 1 | 0 | 1 | 1 | | | | | | | | | | | | | | • | SU00345 | Figure 14. CSR Programmed for Use as an Interrupt Driven Parallel Transmitter Figure 15. Flow Chart for an Interrupt Driven Parallel Transmitter AN408 | CSR 7 | CSR 6 | CSR 5 | CSR 4 | CSR 3 | CSR 2 | CSR 1 | CSR 0 | | |-------|-------|-------|-------|-------|-------|-------|-------|---------| | MB1 | мво | MA1 | MA0 | OBFC | IDSM | OBF | IBF | | | 1 | 0 | 0 | 1 | 1 | 0 | | | | | | | | | | | | | SU00347 | Figure 16. CSR Programmed for Use as an Interrupt Driven Parallel Receiver Figure 17. Flow Chart of Interrupt Driven Parallel Receiver Operation ### **SOFTWARE EXAMPLES** The software for the interrupt driven parallel receiver is similar to the polled receiver example. However, after an interrupt is received, this routine checks to confirm that data has been latched by the positive edge of the strobe pulse before proceeding with the routine. | INIT: | MOV CSR,#090H<br>SETB EX0<br>SETB IT0<br>SETB EA | ;INITIALIZE CSR<br>;ENABLE INTERRUPT 0<br>;SET NEG EDGE TRIGGERED INTERRUPTS<br>;ENABLE ALL INTERRUPTS<br>;INTERRUPT 0 VECTOR | |-----------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ONG EXTID | JMP RCVR | | | RCVR: | RCVR:<br>JNB CSR.0,#<br>CLR CSR.4<br>MOV R7,#02H<br>DJNZ R7,#<br>MOV A,P6<br>MOV R7,#02H<br>DJNZ R7,\$<br>SETB CSR.4 | ;CONFIRM DATA LATCHED ;START ACKNOWLEDGE PULSE ;INITIALIZE THE DELAY COUNTER ;TIME ACK PULSE ;READ BYTE - RESET BUSY LINE ;INITIALIZE THE DELAY COUNTER ;TIME ACK PULSE ;END ACK PULSE | | | RET1 | | **AN408** This is the software for the interrupt driven parallel transmitter example. ; XMIT ROUTINE DRIVEN BY ACK PULSE GENERATED INTERRUPTS, OR TIME GENERATED INTERRUPTS ; FOR NON ACKNOWLEDGING PRINTERS. READS DATA BUFFER IN EXTERNAL RAM STARTING AT 100H ; AND READING UNTIL 04H IS FOUND. ORG RESET JMP 26H ORG TIMERO **JMP** PSEND1 ORG EXTI0 **JMP** PSEND1 ORG 26H MOV CSR,#064H MOV TMOD,#002H SETB TO0 CONFIGURE TIMER 0 TO 16 BITS INTO IS EDGE TRIGGERED ;ENABLE INTERRUPTS :PORT 6 MODE SETB EA PSEND: MOV DPTR,#0100H ;SET DPTR TO START OF TEXT :BUFFER ;SET TIMER INTERRUPT PERIOD PSEND1: CONT1: BB: TO: CLR EA ;DISABLE INTERRUPTS AND STOP ;TIMER CLR TR0 **CLR ETO** ;IF ENABLED MOV R7,00H MOV R6,00H ;CLEAR TIMEOUT COUNTER MOV TH0,#-4 MOV TL0,#00H JB 0C8H,BB :BUS BUSY MOV ACC,#00H ;CLEAR ACCUMULATOR MOVX 1,@DPTR ;RETRIEVE FIRST BYTE MOV 06.ACC **;OUTPUT FIRST BYTE** CJNE A,#004H, CONT1 ;LOOK FOR END OF TEXT JMP EOTB SETB ERX0 :ENABLE INTO CKR 0EEH INC DPTR START STROBE PULSE MOV ACC, DPH JB ACC.2,EOTB ;LOOK FOR PHYSICAL END OF ;TEXT BUFFER SETB 0EEH JMP CONT EOTB: CLR EX0 END OF TEXT FOUND, DISABLE :INTO SETB OEEH SETB EA RETI INC R7 COUNT TIMER TIMEOUTS ON ;BUS BUSY LOOK FOR OVERFLOW CJNE R7,#00H, CONT INC R6 COUNT OVERFLOWS CJNE R6,#10H, CONT ;TIMEOUT APPROX 5 SEC JMP TO CONT: SETB TRO ENABLE TIMER INTERRUPT SETB ET0 START TIMER SETB EA RETI CLR 0C9H SEND NEW STROBE PULSE IN RESPONSE TO TIMEOUT NOP NOP MOV R6,#00H ;RESET TO COUNTER MOV R7.#00H SETB 0C9H JMP PSEND1 END OF STROBE PULSE March 1988 587 Philips Semiconductors Application note # 256k Centronics printer buffer using the 87C451 microcontroller **AN417** ### DESCRIPTION This application note describes a stand alone Centronics type parallel printer buffer using the 87C451 expanded I/O microcontroller. This type of unit would typically be placed between a personal computer and its printer. It captures the data to be printed at high speed, freeing the personal computer to go to other tasks, and sends data to the printer as required. As described here, 256k dynamic RAMs are used, providing over one quarter million characters of storage. If desired the design is easily modified to work with 1 megabit DRAMs. Although written with the 87C451 in mind, this design is applicable to the 80C451 and 83C451. ### **Design Objectives** The objectives kept in mind during the design of this device were: provide a substantial size of buffer, keep the parts count and the power consumption to a minimum, and use readily available components. A buffer size of 256k bytes was chosen because, although a 64k byte buffer is very easily implemented using the 8051 family's 64k external data storage capabilities, it is a little too small for today's printing applications that print a page of text in graphics mode, using up twenty times as many bytes as standard printing mode. Presenting a method for controlling 256k DRAMs shows off the I/O capabilities of the 87C451, and it is very easy to add the extra address line for one megabit devices if a larger buffer is needed. #### The 8XC451 Microcontroller The 8XC451 is an 8-bit microcontroller based on the familiar 8051 family of devices. In fact, it is an 80C51 with three added ports: P4, P5, and P6. Ports 4 and 5 give 12 (16 in PLCC) additional quasi-bidirectional I/O lines. Port 6 provides another 8 bits of I/O, plus 4 handshake lines that can be programmed to operate in several useful modes for interfacing. The 8XC451 comes in three versions: ROMless 80C451, 83C451 with 4k × 8 ROM, and 87C451 with 4k × 8 EPROM. In this note, port 6 is used in the I/O mode as a Centronics compatible printer output port. Additionally, the /IDS and BFLAG pins normally associated with port 6 are used as part of the input port logic. For a complete discussion of port 6 operating modes and programming, see the application note AN408 titled "83C451 Microcontroller Operation of Port 6." ### **Circuit Description** Figure 1 is a schematic diagram of the printer buffer circuit. Other than the 87C451 (U1), and the eight 256k DRAMs (U5-U12), only two 74LS244 buffers (U2, U3) and a 76HCT374 (U4) octal flip-flop are needed. The U2 and U3 buffers are included to provide full drive capability for the output port and some of the handshake signals on the input port, as the output buffers on the 87C451 can only drive 3 LSTTL loads. U4 has 8-bit data strobed into it by the /STB pulse of the input port. As the code size for this application is quite small (less than 1k bytes), the on-chip instruction memory is quite sufficient for program storage. For a production version, the 87C451 could be replaced with the 83C451 with a 4k × 8 masked ROM on chip. Note that port 0 and port 1 are not used in the present design; thus the 80C451 may be used in this application with the addition of an external address latch and EPROM. The /RAS, /CAS, and /WR signals for the DRAM array are provided by port 3 bits /WR. /RD, and T1. Note that as in the 80C51, all port 3 signals are multifunctional. That is, each can be treated as a regular quasi-bidirectional port bit, or as having the special function indicated by its name. This feature is an advantage when using /WR and /RD as /RAS and /CAS control signals for a DRAM array. Treated as a normal port bit, the /WR pin is cleared and set by individual CLR and SETB instructions for a normal length RAM read or write cycle. However, when performing a refresh cycle, /RAS (port 3/WR) can be pulsed low using a dummy MOVX @R0,A (move to external data memory) instruction. This allows DRAM refresh to be done much more quickly than would otherwise be possible. Port 1 and one bit from port 4 form the 9-bit address required when addressing the DRAM array. The data inputs to the array come from the parallel input data lines which are latched by U4. The RAM data outputs are fed to port 5. By making the data outputs available to the processor, it is possible to add some additional features to the firmware, such as control codes for printing multiple copies of a document, data compression, data conversion, etc. which are not implemented in this design. ### **Port 6 Operation** The /IDS (input data strobe) and BFLAG pins are normally used in conjunction with the port 6 bidirectional mode. In this mode, the /IDS pin is used to strobe data into the port 6 input latches, and BFLAG is used as flag output. In this application, however, these two bits are used to good effect as part of the (separate) input port logic. When a byte of data is strobed into U4 by the printer port of the host computer, the /STB signal connected to /IDS sets the input buffer full flag (IBF). BFLAG is programmed to mirror the contents of IBF, and therefore becomes asserted. This makes it ideal to be used as the BUSY output for the input port. After the input port data has been read and stored in the RAM buffer, BFLAG is de-asserted by performing a dummy read of port 6, which clears IBF. To complete the input port logic, one of the port 3 pins, P3.4, is used as the acknowledge signal, and is asserted/de-asserted by software. The /ODS pin is tied to ground to permanently enable the port 6 output drivers. This does not cause difficulty as no data is being input into the nort Note that programming port 6 to operate in the bidirectional mode as described above means the loss of /ODS as an acknowledge input. The acknowledge input is normally used to clear the OBF (output buffer full) flag, indicating that the printer is ready for another character. On the other hand, operating port 6 in the "output only" mode causes the loss of BFLAG as BUSY output. Because the input port requires an instant BUSY indication while the output port only needs to remember the occurrence of an acknowledge pulse, it makes sense to program port 6 to operate in the bidirectional mode, with /ODS grounded to enable the output drivers. The /INT1 pin can be used instead of /ODS to record the occurrence of an acknowledge pulse with the interrupt system. ### **Priority and Execution of Tasks** There are three tasks that must be performed in this system: Receive—servicing the input port and storing the input character; Transmit—sending stored characters to the output port as required; and Refresh—performing DRAM refresh. The timers and interrupt system are used to manage the execution and priority of these tasks. Figure 2 and Figure 3 illustrate the flow charts of these tasks. Firmware, broken into sections, performing these three functions as well as an initialization routine is provided. The 51C256 DRAMs require a 256 row refresh every 4 milliseconds. Rather than do an entire refresh cycle every 4 milliseconds, it is done as 64 rows every millisecond. This leaves time for other tasks to get service "slices" more frequently. As DRAM refresh is obviously the highest priority, timer 0 is used as the refresh interval timer, and is programmed to the 16-bit mode, and set to the higher priority level in the interrupt priority (IP) register. The refresh code is written in-line rather than in a loop to maximize speed. An interesting point to note is that when there are no characters stored, the DRAM does not need to be refreshed. If power consumption AN417 is of concern, the 87C451 could be programmed to go into idle mode whenever the buffer were empty. A character strobed into the input port would cause an interrupt, restarting the 87C451; DRAM refresh would be maintained until the buffer was once again empty. The next highest priority should be input port service, as the reason for having a printer buffer is to get the data out of the computer as quickly as possible. Therefore, the input port /STB signal is connected to the /INT0 pin (as well as U4's clock pin and /IDS). Interrupt 0 is programmed in the interrupt priority register to be at the lower interrupt level so it cannot prevent refresh service. The interrupt 0 service routine stores the input character at the next location in the DRAM array, using the technique of a circular FIFO buffer. The routine also sends back an acknowledge pulse by clearing and setting the P3.4 pin, and then clears the BUSY (BFLAG) pin by performing a dummy read of port 6 (unless this character caused the buffer to be completely full). During periods of access to the DRAM array by the input and output routines, the global interrupt enable bit (EA) is cleared so that the refresh interrupt does not disturb the contents of ports 1 and 4, or the /RAS, /CAS, and /WR signals. The printer (output port) service routine runs all the time, except when the CPU is called to service the other conditions, therefore having the lowest priority. If there are characters in the buffer, polling is used to check for output port BUSY status. If the printer is not busy, then the character is sent, and the output port /STB pin (P4.3) is cleared and set. The output port /ACK line is connected to the /INT1 pin, so that the negative going edge of the /ACK signal is recorded as an interrupt pending. A very short INT1 service routine sets a software flag to indicate that the printer acknowledge the last character. ### **Possible Enhancements** There are a number of features that could be added to this design. As mentioned previously, the microcontroller could be put into the idle mode when the buffer is empty, conserving power. The software could be enhanced to provide features such as multiple copies of a document, data compression, data conversion, automatic printer setup, etc. The PC operating system could be suitably modified to send a header for each file to be printed, containing these parameters. There is plenty of room for operating firmware expansion, and plenty of horsepower left in the 87C451 to handle these features. The two serial port pins RxD and TxD were deliberately left unused so that input and/or output ports are easily implemented for serial interfaces or printers using the built-in UART. The pins used for parallel port handshaking could then be used as serial handshaking lines, providing the standard "modem" signals. Combining the above two features, this circuit could act as a "splitter." By connecting a daisy-wheel printer to the serial port, a dot-matrix printer to the parallel port, and sending an "address" flag in the file header, simultaneous letter-quality and draft printing could be done. The size of the DRAM array is easily expanded to one megabyte or large devices by connecting the additional address pins to port 4 bits 1 and 2. Only slight modifications to the operating firmware would be required. ### Conclusion The SC8XC451 microcontrollers provide plenty of I/O pins that previously had to be implemented by clumsy I/O expansion methods. The flexibility of port 6 means that this device can be used in a wide variety of applications requiring special port functions, while still using the industry standard 8051 instruction set. The Application Note, describing a typical parallel printer buffer, makes full use of the 8XC451 features, yet allows room for enhancement and expansion. Figure 1. Schematic Diagram Figure 2. Flowchart of Transmit Operation Figure 3. Flowchart of Receive and Refresh Operation AN417 XMIT: MOV DPTR,8001H TEST: MOVX A,@DPTR :READ THE CSR JB ACC.0,TEST ;TEST IBF FLAG ### 256K PRINTER BUFFER PROGRAM USING THE 8xC451 FOR CENTRONICS PARALLEL PRINTER PORTS PHILIPS SEMICONDUCTORS OCTOBER, 1988 \$Mod451 \$Title(\*XC451 Printer Buffer) \$Date(10/28/88) ### PORT USAGE: P0 Not used (reserved for data/address bus when external program memory is used). Lower 8 bits of DRAM address (A0 - A7). P2 Not used (reserved for high-order address bus when external program memory is used). P3.0 (Reserved for serial port.) P3.1 (Reserved for serial port.) P3.2 (/INT0) Input port strobe input (interrupt). P3.3 (/INT1) Output port acknowledge input (interrupt). P3.4 Input port acknowledge output. P3.5 DRAM write enable output. P3.6 (/WR) DRAM row address select output. P3.7 (/RD) DRAM column address select output. P4.0 Upper bit of DRAM address (A8). P4.1 Reserved as an extra address line for 1 megabit DRAMS. P4.2 P4.3 Output port busy input (OBUSY). P4.4-P4.7 Unused (not available on 64-pin DIP package). P5 DRAM output data. P6 Parallel output port. /IDS Input port strobe input (ISTB). **BFLAG** Input port busy output (IBUSY). **AFLAG** Output port strobe output (OSTB). /ODS Port 6 output enable, tied low. ### Internal Register/RAM Usage: REFCNT EQU 020h : Low order refresh byte.; The following refer to the circular FIFO buffer implemented in the DRAM array. | INLOW | EQU | 22h | ; Incoming address low byte. | |--------|-----|-----|-------------------------------| | INMID | EQU | 23h | ; Incoming address mid byte. | | INHI | EQU | 24h | ; Incoming address high byte. | | OUTLOW | EQU | 25h | ; Outgoing address low byte. | | OUTMID | EQU | 26h | ; Outgoing address mid byte. | | OUTHI | EQU | 27h | ; Outgoing address high byte. | OACK EQU 28h ; Holds flag for output port acknowledge. BIT FOACK OACK.0 ; Bit-address of output port acknowledge flag. **AN417** | Miscel | laneous | Equates: | |--------|---------|----------| | | | | | TIME | EQU | -1000 | ; Value for 1000 timer clocks = 1 millisecond. | |--------|-----|-----------|------------------------------------------------| | TIMEHI | EQU | HIGH TIME | ; High byte of timer value. | | TIMELO | EQU | LOW TIME | ; Low byte of timer value. | | RAS | BIT | P3.6 | ; DRAM column address select. | | CAS | BIT | P3.7 | ; DRAM row address select. | | DRAMWR | BIT | P3.5 | ; DRAM write control line. | | IACK | BIT | P3.4 | ; Input port ACK output. | | ISTB | BIT | P3.2 | ; Input port strobe line (INT0). | | OBUSY | BIT | P4.3 | ; Output port BUSY input. | | OSTB | BIT | MA0 | ; Output port strobe (MA0 bit in port 6 CSR). | Power-on reset. ; Initialize stack pointer. ; Initialize refresh counter. ; Initialize FIFO pointers. ; Timer0 high priority. 594 #### Reset and Interrupt Jump Table | ORG | 00h | ; | |------|-------|---| | AJMP | START | | | | | | ; INT 0. ORG 03h ; Data at input port. AJMP **INDATA** ORG 0Bh ; Timer 0. AJMP REFRESH ; Refresh DRAM array. ; INT 1. ORG **OPACK** AJMP Output port acknowledge. Power up reset routine: Set up refresh timer, enable timer interrupt and external interrupt, initialize circular buffer pointers. ORG START: MOV SP,#40h MOV A,#00 MOV REFCNT, A MOV INLOW,A MOV INMID,A MOV INHI,A MOV OUTLOW, A MOV OUTMID,A MOV ;Initialize interrupt priority register so that DRAM refresh (TF0) gets high priority, input port service (IE0) and output port acknowledge service get lower priority. All other OUTHI,A interrupts set to lower priority level. MOV IE,#00000111b ; Timer0, INT0, and INT1 enabled. MOV IP.#00000010b MOV TL0,#TIMELO MOV TH0,#TIMEHI MOV TMOD,#00000001b; Operate Timer0 in mode 1. MOV TCON,#00010101b; Timer0 run, I0 and I1 = edge. January 1992 AN417 ``` Initialize Port 6 Control and Status Register. 'BFLAG' mode set to output value of IBF (input port BUSY signal: IBUSY) 'AFLAG' set as logic 1 output (output port strobe signal: OSTB) 'IDS' active on negative level (input port strobe signal: ISTB) MOV CSR,#10011100b MOV A.P6 ; Dummy read of P6 to clear IBF (IBUSY). SETB EA ; Enable interrupts. Executes while not performing DRAM refresh or servicing input port interrupt. Check if buffer is not empty by comparing input and output pointers. If not empty, go to NOTMT to output a byte. MAINLP: MOV A,INLOW ; Compare pointers. CJNE A.OUTLOW.NOTMT MOV A,INMID CJNE A,OUTMID,NOTMT MOV A,INHI CJNE A,OUTHI,NOTMT SJMP MAINLP Buffer is not empty: compute row & column addresses for a read cycle from DRAM. NOTMT: MOV R4,OUTLOW ; Save low byte of row. MOV R5,OUTMID Save upper bit of row. MOV A,OUTHI ; Shift to align correctly. RRC MOV R7,A ; Save upper column bit. MOV A,OUTMID Get low byte of column. RRC Shift in bit from OUTHI. MOV R<sub>6</sub>.A : Save. Now do actual DRAM access to get the data byte at computed address. Disable interrupts so we don't lose what we put out on the ports. CLR EΑ ; Disable interrupts. MOV P1,R4 ; Low byte row address. MOV A,R5 ; Get high byte row address. ORL A,#0FEh ; Make sure OBUSY stays high. MOV P4,A CLR RAS : /RAS low. MOV P1,R6 ; Low byte column address. MOV A,R7 ; High byte column address. ORL A,#0FEh ; Make sure OBUSY stays high. MOV P4,A CLR CAS : /CAS low. MOV R4,P5 ; Get the data byte SETB CAS ; /CAS high. SETB RAS ; /RAS high. CLR FOACK ; Clear acknowledge flag. ``` SETB EΑ ; Re-enable interrupts. AN417 JB OBUSY,PLOOP1 PLOOP1: ; Loop if printer busy. CLR EΑ ; Disable interrupts. MOV P6,R4 ; Move byte to output port. CLR MA0 ; Assert output port strobe. ; Kill some time. NOP NOP NOP NOP **SETB** MA0 ; De-assert output port strobe. ; Re-enable interrupts. **SETB** EΑ Following waits for /ACk to occur on output port. Loops on acknowledge flag which is set by INT1 service routine when /ACK occurs. PLOOP2: JNB FOACK,PLOOP2 ; Wait till /ACK occurs. INC OUTLOW ; Increment output buffer pointer. A,OUTLOW MOV CJNE A,#00,PDONE INC OUTMID MOV A,OUTMID A.#00.PDONE CJNE MOV A,OUTHI INC ANL A,#03h ; Eliminate unused address bits MOV OUTHI,A ; and save. Check if input port busy flag was left asserted, indicating that the buffer was full after last input. If so, acknowledge input port and de-assert input busy signal. IBF, MAINLP PDONE: **JNB** ; Not busy, return to main loop. CLR EΑ ; Disable interrupts. CLR IACK ; Assert /IACK. NOP ; Wait 7 microseconds. NOP NOP NOP NOP NOP NOP ; Dummy read of P6 clears IBF (IBUSY). MOV A,P6 NOP ; Wait 5 microseconds. NOP NOP NOP NOP **IACK SETB** ; De-assert /IACK. SETB EΑ ; Re-enable interrupts. **AJMP** MAINLP ; Return to main loop. **AN417** ``` Interrupt 1 Service Routine: Called when output port asserts /ACK. Sets FOACK flag and returns. OPACK: SETB FOACK RETI DRAM Refresh (Timer0) Interrupt Service: Called once every millisecond by timer interrupt. Refreshes 64 rows and then returns. Therefore refreshes all rows every 4 milliseconds. (Note that 41256/51C256 DRAM only requires a 256 row refresh.) REFRESH: PUSH PSW MOV TH0,#TIMEHI ; Reload timer registers. MOV TL0,#TIMELO MOV P1,REFCNT ; Get next row to refresh. MOVX @R0,A ; Pulse /RAS (/WR). INC P1 MOVX @R0,A ; 1 INC P1 MOVX @R0,A ; 2 INC P1 MOVX @R0,A ; 3 INC P1 MOVX @R0,A ; 4 INC P1 MOVX @R0,A ; 5 INC P1 MOVX @R0,A ; 6 INC P1 MOVX @R0,A ;7 INC P1 MOVX @R0,A : 8 INC P1 MOVX @R0,A ; 9 INC P1 MOVX @R0,A ; 10 INC P1 MOVX @R0,A ; 11 INC P1 MOVX @R0,A : 12 INC P1 MOVX @R0,A ; 13 INC P1 MOVX @R0,A ; 14 INC P1 MOVX @R0,A INC P1 MOVX @R0,A ; 16 INC P1 MOVX @R0,A ; 17 INC P1 MOVX @R0,A ; 18 INC MOVX @R0,A ; 19 INC P1 MOVX @R0,A ; 20 INC P1 ``` **AN417** | MOVX | @R0,A | ; 21 | |-------------|-------------|------| | MOVX | P1<br>@R0,A | ; 22 | | MOVX | P1<br>@R0,A | ; 23 | | INC<br>MOVX | P1<br>@R0,A | ; 24 | | INC<br>MOVX | P1<br>@R0,A | ; 25 | | INC<br>MOVX | P1<br>@R0,A | ; 26 | | INC<br>MOVX | P1<br>@R0,A | : 27 | | INC<br>MOVX | P1<br>@R0,A | ; 28 | | INC | P1 | | | MOVX<br>INC | @R0,A<br>P1 | ; 29 | | MOVX | @R0,A<br>P1 | ; 30 | | MOVX<br>INC | @R0,A<br>P1 | ; 31 | | MOVX<br>INC | @R0,A<br>P1 | ; 32 | | MOVX | @R0,A | ; 33 | | INC<br>MOVX | P1<br>@R0,A | ; 34 | | INC<br>MOVX | P1<br>@R0,A | ; 35 | | INC<br>MOVX | P1<br>@R0,A | ; 36 | | INC<br>MOVX | P1<br>@R0,A | ; 37 | | INC<br>MOVX | P1<br>@R0,A | ; 38 | | INC | P1 | | | MOVX | @R0,A<br>P1 | ; 39 | | MOVX | @R0,A<br>P1 | ; 40 | | MOVX<br>INC | @R0,A<br>P1 | ; 41 | | MOVX | @R0,A<br>P1 | ; 42 | | MOVX | @R0,A | ; 43 | | INC<br>MOVX | P1<br>@R0,A | ; 44 | | INC<br>MOVX | P1<br>@R0,A | ; 45 | | INC<br>MOVX | P1<br>@R0,A | ; 46 | | INC<br>MOVX | P1<br>@R0,A | ; 47 | | INC<br>MOVX | P1<br>@R0,A | ; 48 | | INC | P1 | ·. | | MOVX<br>INC | @R0,A<br>P1 | ; 49 | | MOVX | @R0,A<br>P1 | ; 50 | | MOVX | @R0,A<br>P1 | ; 51 | | MOVX<br>INC | @R0,A<br>P1 | ; 52 | | MOVX | @R0,A | ; 53 | | MOVX | P1<br>@R0,A | ; 54 | | INC | P1 | | 598 AN417 | MOVX | @R0,A | ; 55 | |------|-----------|-----------------------| | INC | P1 | | | MOVX | @R0,A | ; 56 | | INC | P1 | | | MOVX | @R0,A | ; 57 | | INC | P1 | | | MOVX | @R0,A | ; 58 | | INC | P1 | | | MOVX | @R0,A | ; 59 | | INC | P1 | | | MOVX | @R0,A | ; 60 | | INC | P1 | | | MOVX | @R0,A | ; 61 | | INC | P1 | | | MOVX | @R0,A | ; 62 | | INC | P1 | | | MOVX | @R0,A | ; 63 | | INC | P1 | | | INC | P1 | ; Adjust for next tim | | MOV | REFCNT,P1 | ; and save. | | POP | PSW | | | RETI | | | #### Data at Input Port: This routine is called via interrupt INTO whenever data is strobed into the input port. It saves the data into the DRAM array and increments the input pointer. If the output pointer is now equal to the input pointer, then the buffer is full, and we leave the busy flag set so that no more data can be input until some is output and the buffer is no longer full. ``` INDATA: PUSH PSW PUSH ACC MOV R1,INLOW ; Lower 8 bits of row to R1. MOV R2,INMID ; Upper bit of row to R2. MOV A,INHI ; Get upper 2 bits. RRC ; LSB to carry. MOV R0.A MOV A,INMID RRC ; Shift bit into MSB. MOV R3,A : Save. CLR EΑ ; Disable interrupts. MOV P1,R1 ; LSB Row address. MOV ; MSB row address. A,R2 ORL A,#0FEh : Make sure OBUSY stays high. MOV P4,A ; MSB row address. STBLP: JNB ISTB, STBLP ; Check for end of strobe before DRAM write. CLR RAS ; /RAS low. CLR DRAMWR ; /WR low. MOV : LSB column address. P1,R3 MOV 1,R0 ; MSB column address. ORL A,#0FEh ; Make sure OBUSY stays high. MOV P4,A ; MSB column address. MOVX A,@R0 ; Pulse /CAS low. SETB RAS ; /RAS high. SETB DRAMWR ; /WR high. SETB EΑ ; Re-enable interrupts. ``` AN417 INC INLOW ; Increment input buffer pointer. MOV A,INLOW CJNE A,#00,CKFULL CJNE A,#00,CKFULL INC INMID MOV A,INMID CJNE A,#00,CKFULL MOV A,INHI INC A ANL A,#03h MOV INHI,A ; Eliminate unused address bits. Compare input pointer to output pointer to see if the buffer is full. CKFULL: MOV A,INLOW CJNE A,OUTLOW,INCLR MOV A,INMID CJNE A,OUTMID,INCLR MOV A,INHI CJNE A,OUTHI,INCLR If we get here, the buffer is full, so skip the acknowledge pulse. SJMP INDONE Send acknowledge pulse on /IACK line for 7 microseconds, de-assert input BUSY signal halfway through. ; INCLR: CLR EA ; Disable interrupts. CLR IACK ; Assert /IACK. NOP ; Wait 7 microseconds. NOP NOP NOP NOP NOP MOV A,P6 ; Dummy read of P6 clears IBF (IBUSY). NOP ; Wait 5 microseconds before clearing /IACK. INDONE: POP ACC POP PSW SETB IACK ; De-assert /IACK. SETB EA ; Re-enable interrupts. RETI END **AN418** #### **INTRODUCTION TO THE 83C552** The 83C552 is an 80C51 derivative with several extended features: 8k ROM, 256 bytes RAM, 10-bit A/D converter, two PWM channels, two serial I/O channels, six 8-bit I/O ports, and four counter/timers. The architecture of the 83C552 is identical to that of the 80C51, making the two devices fully code compatible. The additional peripheral functions are added to the 80C51 Special Function Register space, and the interrupt structure is modified accordingly. This information is detailed in other references on the 83C552. The focus of this application note is on one of the timers of the 83C552, Counter/Timer 2. This counter/timer includes capture, compare, and high-speed output capabilities which facilitate many control oriented tasks. The objective of this note is to make users of the 83C552 aware of this counter/timer subsystem and assist the use of this subsystem by a detailed explanation of its operation supported by actual application examples. ### **TIMER 2 OF THE 83C552** Timer 2 of the 83C552 is in fact a timing controller and has an associated programmable array. The Timer 2 subsystem consists of three parts: - The time base consists of a 16-bit timer with a 3-bit prescaler. The master clock for the subsystem can be derived from the on-chip oscillator (fosc) or an external input, T2. It has an external reset, RT2, by which a signal applied to this input can reset the timer if the external reset is enabled. - A capture system consisting of four capture registers and four capture inputs which can be used for a wide variety of time measurements on external signals. - A compare system consisting of three compare registers and eight associated high-speed outputs which can be activated upon a match between the 16-bit timer and one of the compare registers. For reference a complete block diagram of the 83C552 Counter/Timer 2 subsystem is shown in Figure 1. ### **16-BIT COUNTER/TIMER** The description of Counter/Timer 2 in the following paragraphs is intended to be a general overview. Details on architecture, address locations, interrupt structure, and timer operation are given in the 83C552 Users Manual. This users manual may be useful to complement the material presented in this application note. References to registers, bits, I/O ports, and on-chip hardware will relate directly to 83C552 Users Manual nomenclature. This application note will focus on the use of Counter/Timer 2 as a powerful input capture and high-speed output facilitator through some specific examples and not on the detailed coding. The counter/timer consists of a 16-bit counter which is readable by software through special function registers TM2L and TM2H. The timer itself has two overflow flags, one after the entire 16-bit counter and one attached to the eighth stage. This latter flag reflects an overflow from the first byte of the counter. These two flags are present in register TM2IR and are labeled T2BO for the overflow from the first byte and T2OV for the overflow from the entire 16 bits. These flags may be used to generate an interrupt. The counter timer is controlled directly through the special function register TM2CON, the timer 2 control register. This register also contains certain status flags. The prescaler divides the input clock by a programmable ratio. The prescaler divide value is programmable to divide by 1, 2, 4, or 8 as controlled by T2PO and T2P1 in TM2CON. The input clock to the prescaler is either fosc/12 or the external input, T2. The clock input to the prescaler may also be shut off. This clock input selection is controlled by bits T2MS0 and T2MS1 in TM2CON. If T2 is used as the input clock to the timer 2 subsystem, the hardware logic samples this input and looks for a low-to-high transition. If the logic detects a logic 0 at the T2 input in state S2P1 of the microcontroller and a logic 1 in state S5P1, then this is recognized as a low-to-high transition, and the prescaler is incremented. The prescaler is incremented in the second cycle after the cycle in which the transition was detected. If the transition is detected before S2P1 is finished, the prescaler is incremented in the next cycle. This timing is shown in Figure 2. Note that this sampling rate is twice that of the normal 80C51 timers, T0 and T1; therefore T2 has twice the maximum external counting rate as compared to the standard timers. Any programming of the clock source or the prescaler divide ratio results in a reset of the prescaler. This allows the state of the timer subsystem to be in a known state upon programming. The main 16-bit timer cannot be reset by software but it is reset by activating the reset pin or using the external reset, RT2. The external reset, RT2, can be enabled or disabled by bit T2ER in TM2CON. These resets reset the prescaler as well as the 16-bit counter. Only one interrupt is available from the 16-bit counter timer. Two bits in TM2CON control whether TM2L, TM2H, or both flags will be used to generate the interrupt. A selection for no interrupt is also possible. ### **Capture System** The capture system is a powerful tool to measure the width of pulses or repetition rates. There are four independent inputs for the signals to be analyzed, CTI0 through CTI3. These inputs are alternate functions to port 1. Each input is connected to a dedicated capture register. A transition at any of these inputs will cause the content of the 16-bit counter/timer to be loaded into the respective capture register. The capture can occur upon various conditions of the input signal as specified by certain bits in the capture control register, CTCON. Each input can be set to cause a capture on a low-to-high transition, a high-to-low transition. or on both transitions. Upon a capture taking place, each input causes an interrupt flag to be set in the Timer 2 Interrupt Flag Register. TM2IR. If enabled, an interrupt will be generated. One of the capture inputs is shown in more detail in Figure 3. All of the other capture inputs are similar to this one. The capture input is gated with the capture enable bits CTN0 and CTP0, which are located in CTCON. According to the status of these bits, the desired edges are selected to generate the capture enable pulse. The input pulse transient detection is at the input of the enable pulse generator. The input signal is sampled at S1P1 of the machine cycle. If a logic 1 is detected when a logic 0 was detected at the same time in the previous cycle, then the event is taken as a transition. An enable pulse is sent to the capture register, and the contents of timer 2 is copied into the capture register at the end of this machine cycle. The interrupt flag CTI0 is also set. Figure 1. 83C552 Counter/Timer 2 Block Diagram **AN418** Figure 2. The Sampling of the External Clock Signal Figure 3. Capture Subsystem for CTO1 **AN418** ### **Compare System** The compare system of Timer 2 can be used to generate a set of outputs whose transitions are controlled directly by the time defined by the 16-bit counter/timer. There are eight of these high-speed outputs which are directly controlled from Counter/Timer 2. These outputs are alternate functions to port 4. Six of these outputs are set-reset controlled (CMSR0 through CMSR5), and two are toggle controlled (CMT0 and CMT1). To clarify the operation, these two types will be discussed separately. In the following discussions, refer to Figure 4, which shows the compare system for P4.5 (a set-reset high-speed output) and P4.6 (a toggle high-speed output). There are two compare registers associated with the set-reset outputs. These registers are CM0 and CM1. In addition, there are two enable registers: one to enable setting of an output and the other to enable resetting of an output. These registers are STE and RTE, respectively. The contents of CM0 and CM1 are continuously compared to the contents of the 16-bit counter. Whenever there is a match between the 16-bit counter and the contents of CM0, a SET pulse is generated. Similarly, whenever there is a match between the timer and the contents of CM1, a RESET pulse is generated. The set pulse is applied to the set-reset outputs, CMSR0 through CMSR5, through gates controlled by bits in STE. Bits 0 through 5 in STE control the application of the SET pulse to one of the high-speed outputs. For example, STE.0 controls the gating of the SET pulse to CMSR0, STE.1 controls the gating of the SET pulse to CMSR1, and so forth. Thus, if the corresponding SET enable bit in STE is a 1 and a compare occurs with CMO, then that high-speed output will become set. Similarly, the reset pulse from CM1 is applied to the high-speed outputs CMSR0 through CMSR5 through gates controlled by bits in RTE. As with STE, bits 0 through 5 in RTE control the application of the reset pulse to one of the high-speed outputs. If a compare occurs between the timer and CM1, a high-speed output will be reset if its corresponding enable bit in RTE is a 1. Compares with CM0 and CM1 set interrupt flags which, if enabled, can be used to generate an interrupt. The two toggle-controlled outputs are CMT0 and CMT1, and these are associated with compare register CM2. These outputs are also alternate functions on port 4. Upon a compare between the counter and the contents of CM2, CM2 generates a toggle pulse which is applied to the high-speed outputs CMT0 and CMT1 through a set of gates. The gates control the application of the toggle pulse to the toggle outputs as specified by the high-order bits of register RTE. RET.6 controls CMT0, and RET.7 controls CMT1. Should the corresponding bit of RTE be set, then the toggle pulse is enabled to the associated high-speed output and that output will toggle upon generation of the toggle pulse from CM2. The structure of these toggled outputs is different from the other high-speed outputs in that the toggling is actually accomplished in a separate toggled flip-flop and not directly in the port latch. This toggle flip-flop cannot be controlled directly by software and powers up in an indeterminate state. The state of the toggle flip-flops is readable in STE bits 6 and 7. Figure 4. Compare System for P4.5 and P4.6 ### APPLICATION EXAMPLE— TIMED FUEL INJECTION In modern automobiles, optimal combustion is necessary to meet emission standards and improve fuel consumption. Optimal combustion depends on several factors and is enhanced by proper fuel injection based upon these factors which vary according to engine speed and other factors. Thus the task is to control the opening and closing of the engine fuel injectors of each cylinder relative to the crankshaft reference point. For the application example here, we will not consider the factors which determine the timing relationships. These are assumed to be given quantities. The example here will focus upon the implementation of the injector timing control signals and how they are generated using the Counter/Timer 2 system. The illustration considers a four cylinder engine. While this is an automotive application which serves to clearly illustrate Counter/Timer 2 Subsystem operation, it is clear that many systems share similar timing requirements, and the techniques employed here are applicable to a wide class of timing tasks. The 83C552 will also support six cylinder engine control. Figure 5 shows the injection timing required for two consecutive revolutions of the engine crankshaft. Start and stop of the injection are given relative to a reference point on the crankshaft. The cylinders are numbered in the order of the injection sequence (not with reference to their physical location). Start of the injection is usually given in angular measure with respect to top dead center, and the injection duration is assumed to be a time value calculated from engine environmental factors and operating parameters. The angle for the start of the injection must be converted into time with respect to the reference point. The injector drivers are assumed to be connected to the port 4 high-speed outputs CMSR0 through CMSR3. To obtain the top dead center reference point, the signal from the appropriate sensor is connected to the capture input CTOI. The interrupt for this capture input is enabled so that software can synchronize its operation to this time reference and make use of the top dead center time in the injector timing calculations. The software synchronization takes two forms. First, the captured time is an absolute reference for all real-time output operations. This time is available in capture register CT0. Note that at 12 MHz operation, Timer 2 can have a resolution as fine as 1 microsecond with a total time before overflow of over 65 milliseconds, and these times are adjustable by increasing the prescaler divide ratio. A proper selection can make the timing calculations relatively simple. Second, at the time the input is captured, flags which keep track of the phases of the crankshaft cycle are reset when cylinder 1 is at top dead center. These flags are used in the interrupt service routines to tell which action is required for that phase of the crankshaft. Consider now the sequence of events in one rotation of the engine crankshaft and refer to Figure 5 during the discussion. Assume that the engine is running, that all relevant parameters are available, and that it has been determined that the processor is responding to the interrupt associated with the top dead center capture, CTOI. Interrupts for CTOI, CM0 (compare register 0), and CM1 (compare register 1) are enabled. Upon entering the interrupt service routine for CTOI, the previous value of the captured top dead center time is subtracted from the present value, and the crankshaft rotation time is determined. This is used to compute the time to open the first injector from the required angle at which the injector is to open. This time is made available for the interrupt service routine which responds to a compare from CM0. The interrupt service routine is exited. The next interrupt to occur per the figure for this example is a result of a compare with CM1 which will be a result of the injector stop time for cylinder 4 having been reached. The flags in an internal status register are employed to keep track of the cylinder number that is presently active for both injection stop and injection start times. After identifying this interrupt from the flags, the processor uses the injector start time for cylinder 1 (previously loaded into CM0) and the predetermined duration to calculate the injector stop time for cylinder 1. This value is loaded into compare register CM1 and the reset enable bit for high-speed output CMSR0 is programmed to a 1. This is bit RTE.0 The reset enable bit for the cylinder 4 injector is set to 0 (bit RET.3). The interrupt routine is now exited. Figure 5. Four Cylinder Injection Timing Philips Semiconductors Application note ### Counter/timer 2 of the 83C552 microcontroller **AN418** The next interrupt to occur will be for the start time for the injector for cylinder 2. This and all subsequent cases follow the same sequence of events as for the cylinder 1 CM0 interrupt described above. In this case, calculations are made for cylinder 2 and loaded into CM0,STE.1 is programmed to a 1, and STE.0 is programmed to a 0. Similarly, the next interrupt for CM1 is treated in the same way, and the sequence of events rotates around through all cylinders in turn. The flag bits associated with this operation keep track of the injector sequencing. While this example shows the injection stop time of one cylinder overlapping into the injector on time of the subsequent cylinder, close examination of the operations described above reveal that the start and stop events are independent and can overlap or not as required. In this way all injectors may be driven independently and have overlapping on times. Given that this is an example applicable to general usage, it is possible that interrupt service routine could be relatively long as it would be in an actual injector application. Since the service routine has other interrupts disabled, the length may cause real-time conflicts. To eliminate this potential problem, the interrupt service routines are divided into two parts. In the first part, all other interrupts are disabled, and the essential register loading is done to prepare for the next interrupt. After this is completed, all interrupts are enabled and the ancillary service routine functions are performed prior to a return to the main routine As an example, consider the interrupt service routine for CM0. Upon entering the routine, all interrupts are disabled. Then the following actions are performed: - Set bit in STE to start next injector - Clear bit in STE for injector just started - Load CM0 with start time for next injector - Clear CMIO interrupt flag in TM2IR Now that the essential set-up is made for the next interrupt, all interrupts are now enabled. However, the return to the main program is not invoked until the following ancillary processing is completed: - Calculate the next absolute start time for the next injector (the next load value for CM0) - Increment the flag so that the next entry to this interrupt service routine will be able to identify the next injector to start. The process performing these calculations can be interrupted to service real-time functions. # APPLICATION EXAMPLE—TIMED IGNITION In electronic ignition systems, multiple ignition coils may be used and each coil is fired by electronic means rather than with the old style mechanical breakers. In a four cylinder engine, there may be two ignition coils, one coil providing spark for a pair of cylinders. Both plugs fire at the same time. For one cylinder, the spark occurs at the appropriate time while for the other cylinder, the spark occurs at the end of the exhaust stroke and has no effect. With timing references to crankshaft top dead center provided by an external sensor, the ignition timing for the engine may be generated in the 83C552 and applied to the electronic drivers for the ignition coils. To illustrate the toggle high-speed outputs of the 83C552 Counter/Timer 2 subsystem, the following example will discuss the ignition timing in a four cylinder engine employing the two coil approach with one coil for a pair of cylinders. The coil timing is illustrated in Figure 6. A reference time is used which is a given interval prior to top dead center so that the times used in the illustration can be always after the reference. There are two times of interest for each coil: the load time and the ignition point. Ignition advance is usually given in degrees crankshaft angle prior to top dead center. As with injection, this angle is assumed to be derived from other calculations and is a given value for this illustration. This angle must be converted in to a time with respect to the reference point. The load time (the time at which the coil has to be switched on to reach the current that will give sufficient energy for an adequate spark) must be subtracted from the desired ignition point. At the ignition time, the coil will be switched off and the spark will be generated. The coil driver electronics are connected to port bits P4.6 and P4.7. Ignition coil 1 is connected to P4.6, and ignition coil 2 is connected to P4.7. These outputs are the toggle high-speed outputs controlled by the 16-bit compare register, CM2. The program simply needs to set up the compare and control registers to turn the coils on and off at the appropriate times. It is assumed in this example that the ignition and load times are given quantities and have been determined previously. Figure 6. Four Cylinder, Two Coil Ignition Timing January 1992 AN418 Consider now the sequence of events in two rotations of the engine crankshaft and refer to Figure 6. Assume that the engine is running. that all relevant parameters are available, and that it has been determined that the processor is responding to the interrupt associated with a compare to CM2. The top dead center time and crankshaft rotation speed have been already determined through the top dead center capture, CTOI. This is the same as in the injector example. The interrupt for CTOI is enabled. From the top dead center time, the times to turn on and turn off the coil drivers are computed and made available in data storage locations in the microcontroller. It is also convenient to have flags to identify the step in the complete ignition cycle. The flags are cleared in the interrupt service routine for top dead center of cylinder 1. Upon entering the interrupt service routine, other interrupts are disabled. Examination of the flags reveals that the state of the ignition sequence is that coil 1 has been turned on to begin the current build up (load time). The next event will therefore be turning off coil 2 to cause ignition. The interrupt service routine then performs the following actions: The time to turn off coil 2 is moved into compare register 2, CM2. Bit 6 of RTE is cleared; this disconnects the output of CM2 from the toggle flip-flop of P4.6 (coil 1). Bit 7 of RTE is set; this connects the output of CM2 to the toggle flip-flop of P4.7 (coil 2). The flags are incremented to indicate that the next interrupt will be a result of coil 2 turning off and causing ignition. The other interrupts can be enabled and a return to the main program can be executed. After the other interrupts are enabled and before a return is made to the main program, it may be convenient to do any necessary calculations to determine the time value to be loaded into CM2 in the next CM2 interrupt. Since the flip-flops are toggled, it is likely that upon power up of the microcontroller, the toggle flip-flops will not be in the desired state. To get the toggle flip-flops in the correct state in the ignition cycle, the flip-flops must be toggled if they are in the wrong state. To determine if this is necessary, the state of the toggle flip-flops can be read from the STE register. The state of the P4.6 flip-flop is present in STE bit 6 and the state of the P4.7 flip-flop is present in STE bit 7. Comparing the actual state to the required state determines which if any or both of the flip-flops must be toggled. If a toggle is necessary to put one or both of the flip-flops in the correct state, the corresponding bits in RTE would be set for those flip-flops requiring the toggle, and CM2 would be loaded with a value that is slightly larger than the present contents of timer 2. If desired for reliability purposes, the state of the flip-flops could be checked periodically against the ignition cycle flags to determine if a correction is necessary. ### CONCLUSION This application note has examined one aspect of the 83C552 CMOS 80C51 derivative microcontroller. The Counter/Timer 2 Subsystem has been applied to a complex timing task of gasoline engine injector valve and ignition coil timing control. While this is a specific application to the automotive interests, the results are applicable to a wide variety of time measurement and control applications. The 83C552 would be ideal for many electromechanical systems such as copy machines, fax machines, industrial process control equipment, automatic transmission control, and anti-skid and anti-lock braking control. These application areas are those which can successfully employ the 83C552 Counter/Timer 2; however, the other features should not be overlooked. When combined with the 10-bit A to D Converter, the Pulse Width Modulator, the I<sup>2</sup>C serial bus, and peripheral device family, the 83C552 provides minimum component count solutions for cellular radio systems, professional audio systems, and medical instrumentation products such as bedside patient monitors and analyzers for home care and sports use. Philips Semiconductors Application note # Using up to 5 external interrupts on 80C51 family microcontrollers AN420 80C51 family microcontrollers are equipped with up to two inputs which may be used as general-purpose interrupts. A typical device provides a total of 5 interrupt sources. Timer 0 and Timer 1 generate vectored interrupts, as does the Serial Port. Applications that require more than two externally signaled vectored interrupts, and do not use one or more of the counters or the serial port, can be configured to use these facilities for additional external interrupt inputs. This note describes a method to configure the timer/counters and the serial port for use as interrupt inputs (see Figure 1). Minimum response time is a goal for this configuration. Another popular method to implement extra interrupt inputs is to poll under software control a port pin configured as an input. This method is necessary when the on-chip peripherals are in use. Applications where this approach is recommended are ones in which the processor spends more than half of the time executing a "wait loop," or a short code sequence which jumps or branches back on itself without performing any functions. In this case, the instructions that will check the state of input used as an interrupt source are inserted into this sequence. Consequently, this input is ignored when other routines are being executed. This input may have to be latched externally, or the processor may miss the signal while executing other routines. Dedicated interrupt inputs that vector the processor to individual service routines (as the two general-purpose interrupt inputs work) do not have the drawbacks of the method described above. # COUNTER/TIMER CONFIGURATION Timers 0 and 1 are placed in mode 2, which configures the timer/register as an 8-bit counter with automatic reload. The counter and reload register are loaded with FF hexadecimal which is stored in TH1 and TL1 or TH0 and TL0. To prepare one of the timers for this kind of operation, a number of control bits have to be set up. The following is a list of these bits and their values: | In Th | MOD: | In TO | CON | : '' | In I | E: | | |-------|-------|-------|-----|-------|------|----|---| | GAT | E = 0 | TRi | = | 1.100 | ETI | = | 1 | | C/T | = 11, | | | | EA | = | 1 | | M1 | = 1 | | | | | | | | NAO. | - 0 | | | | | | | Where "i" is the timer number being used as the external interrupt. The TMOD value would be 66 hexadecimal if both timers are being used as external interrupt sources, x6 hex for timer 0, and 6x hex for timer 1. The interrupt priority may also be set in the IP register. A falling edge on the corresponding Timer 0 or Timer 1 input (T0 or T1) will cause the counter to overflow and generate a timer interrupt. The counter will be automatically loaded with another FF from the reload register, so the interrupt can occur again as soon as the interrupt service routine completes. Counter/Timer operation is described in detail elsewhere in this manual. ### **SERIAL PORT CONFIGURATION** The serial port can be placed in mode 2, which is a 9-bit UART with the baud rate derived from the oscillator. The external interrupt is signaled through this port on the RxD receive data pin. Reception is initiated by a detected 1-to-0 transition at RxD. The signal must stay at 0 for at least five-eighths of a bit period for this level to be recognized. Refer to the description of baud rates to determine the length of a bit period at the oscillator frequency selected for the application. The input signal should remain low for at least one bit period and for not more than 9 bit periods. To prepare the serial port for use as an external interrupt, the following bits must be set up: ### In SCON: SM0 = 1SM1 = 0 SM2 = 0 REN = 1 Figure 1. 80C51 Five Interrupt Configuration January 1992 608 # Using up to 5 external interrupts on 80C51 family microcontrollers AN420 The Serial Port Interrupt is then used as a general-purpose interrupt. The contents of receive buffer should be ignored, and will subsequently be overwritten during the next interrupt. Note that the response time for this input will be slower than for the Counter/Timer inputs. This is due to the fact that the RI is generated after the eighth serial data bit time after the falling edge on RxD. ; Demonstration program for five external interrupts. #### \$MOD51 ; Interrupt Jump Table \$TITLE (Five Vectored External Interrupts) | , interrupt of | ORG<br>AJMP | OH<br>Setup | ;Reset | |-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------| | | ORG<br>RETI | 3H | ;External interrupt 0.<br>;(not implemented in this demo) | | | ORG<br>AJMP | 0BH<br>Tim0 | ;Timer 0 interrupt. | | | ORG<br>RETI | 13H | ;External interrupt 1.<br>;(not implemented in this demo) | | | ORG<br>AJMP | 1BH<br>Tim1 | ;Timer 1 interrupt. | | | ORG<br>AJMP | 23H<br>Serial | ;Serial port interrupt. | | ; Begin setu<br>Setup | p code<br>MOV | SP,#7FH | ;Initialize the stack pointer. | | ; Configure | both timers<br>MOV<br>MOV | TMOD,#66H<br>A,#0FFH | ;Put both counters into mode 2. | | | MOV<br>MOV<br>MOV | TL0,A<br>TH0,A<br>TL1,A<br>TH1,A | ;Load FF hex into both counters | | | SETB<br>SETB<br>SETB<br>SETB | ET0<br>ET1<br>TR0<br>TR1 | ;Enable Timer 0 interrupt.<br>;Enable Timer 1 interrupt.<br>;Enable Timer 0 to run.<br>;Enable Timer 1 to run. | | ; Configure | the serial posetrial poset | ort<br>ES<br>SCON,#90H<br>EA | ;Enable serial port interrupt.<br>;Put the serial port in mode 2.<br>;Enable interrupt system. | | Wait: | NOP<br>JMP | Wait | ;Wait for an interrupt. | | Serial: | NOP<br>CLR<br>RETI | RI | ;Serial interrupt service routine.<br>;Clear receiver interrupt flag. | | Tim0: | NOP<br>RETI | | ;Timer 0 interrupt service routine. | | Tim1: | NOP<br>RETI | | ;Timer 0 interrupt service routine. | | | END | | | Philips Semiconductors Application note ### 8051 family warm boot determinations **AN424** ### **DESCRIPTION** For some classes of applications, it may be desirable to know if the application of the reset signal to a microcontroller is due to an initial power-on sequence, or is the result of an external signal such as an operator pressing a reset pushbutton, or the result of a watchdog timer or similar event. While there are perhaps numerous hardware solutions that can be employed, a simple software solution can offer a high degree of confidence in making this determination. The task is to determine the differences in state of resources internal to the microcontroller that would occur as a result of these two types of reset conditions. With respect to the 80C51 family of microcontrollers, on-chip resources consist of the special function registers (SFRs) and the internal data memory (RAM). Most of the SFR locations are initialized as a result of a reset condition and thus cannot be used for this determination. The data memory contents are unaffected by reset. Thus, valid data loaded into the RAM of the 80C51 while executing a program would not be affected by the application of an external reset signal provided the power source for the microcontroller has not been removed (as is the case for a "warm boot"). The contents of data memory as a result of an initial application of power, however, is indeterminate. While this effect has not been extensively characterized, empirical observation suggests that it is highly random in nature. If it is assumed, for the moment, that the behavior of a given byte of data memory is such that it will power-up with a value that is totally random, then there is a one in eight chance that it will power-up with a predetermined value. If the assumption is extended to two bytes, a 16-bit number, then there is one in 2<sup>16</sup> chance that both bytes will power-up with predetermined values. Extending this to four bytes results in a one in 2<sup>32</sup> chance, a very small probability. This is the basis for the software determination of a warm or cold boot condition. The technique consists of evaluating the contents of four consecutive bytes of data memory following a reset condition to determine whether these bytes had been previously loaded with known data values. If the contents of all four bytes match predetermined values, this is interpreted to be a warm boot condition. If there is no match, it is then interpreted to be a cold boot condition. At this point, it is necessary to load these four bytes with predetermined data to prepare for the possibility of a subsequent warm boot condition. The software example included in this application brief can be used to perform this warm or cold boot determination. The symbols WARM1 thorough WARM4 represent the predetermined values. The symbol WARM is the address of the first of the four consecutive bytes in data memory. It is set to 30H to avoid conflict with the four register banks, the stack, and the bit-addressable locations in data memory. The symbol WARMBT is a bit-addressable location used as a status bit. It is set as the result of a warm boot and cleared as a result of a cold boot. The label START is the location of the first instruction to be executed following a reset (address = 0000H). An instruction is located here to jump into the main body of the program to bypass the interrupt vector locations. The main program body begins by loading register R0 with the address of the first byte in data memory to be evaluated. The contents of this first byte is compared with the first predetermined value. If there is no match, the conclusion is that it is a cold boot. However, if a match is found, this does not imply that it is a warm boot since all four bytes must match, and therefore the remaining three bytes must also be evaluated. Register R0 is incremented to point to the second byte and then compared to the second predetermined value. Comparison of the bytes proceeds until either a no match condition is found or until all four bytes have been evaluated successfully. If all four bytes compared favorable, then a status bit (WARMBT) is set to indicate a warm boot and the remainder of the application program is completed. An unsuccessful comparison results in branching to the label COLD. This section of code clears the status bit (WARMBT) to indicate a cold boot, and loads the four bytes of data memory with the predetermined values preparing the system for a subsequent possible warm boot. Program flow then continues with the remainder of the application program. ## 8051 family warm boot determinations | | 1 | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|----------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 2 | ;warm b | oot appl | ication example | | | | 3 | | | | | | 0030 | 4 | WARM | EQU | 30H | ; first location of the four bytes in RAM | | 0055 | 5 | WARM1 | EQU | 55н | ;first predetermined value | | 00AA | 6 | WARM2 | EQU | 0AAH | ; second predetermined value | | 0033 | 7 | WARM3 | EQU | 33н | ; third predetermined value | | 00CC | 8 | WARM4 | EQU | 0CCH | ; fourth predetermined value | | 0000 | 9 | WARMBT | EQU | 0 | ;warm boot status bit | | | 10 | WAKMDI | EQU | | , warm boot status bit | | 0000 | | | 000 | | | | 0000 | 11 | | ORG | 0 | | | 0000 020026 | 12 | | **** | | | | 0000 020026 | 13 | START: | JMP | MAIN | ; bypass interrupt vectors | | 0006 | 14 | | | | | | 0026 | 15 | | ORG | 26H | | | | 16 | | | | | | 0026 7830 | 17 | MAIN: | MOV | R0,#WARM | ;pointer for first byte | | 0028 B65511 | 18 | | CJNE | @R0,#WARM1,COLD | ;test first byte | | 002B 08 | 19 | | INC | R0 | ;pointer for second byte | | 002C B6AA0D | 20 | | CJNE | @RO,#WARM2,COLD | ;test second byte | | 002F 08 | 21 | | INC | R0 | ;pointer for third byte | | 0030 B63309 | 22 | | CJNE | @RO, #WARM3, COLD | ;test third byte | | 0033 08 | 23 | | INC | R0 | ;pointer for fourth byte | | 0034 B6CC05 | 24 | | CJNE | @RO, #WARM4, COLD | ;test fourth byte | | 0037 D200 | 25 | | SETB | WARMBT | ;this is a warm start | | 0039 02004B | 26 | | JMP | INIT | ; continue with rest of application | | 003C C200 | 27 | COLD: | CLR | WARMBT | ; this is a cold boot | | 003E 7830 | 28 | | MOV | RO,#WARM | ;pointer for first byte | | 0040 7655 | 29 | | MOV | @RO,#WARM1 | ;load the four bytes for future test | | 0042 08 | 30 | | INC | R0 | <b>1</b> | | 0043 76AA | 31 | | MOV | @RO,#WARM2 | | | 0045 08 | 32 | | INC | RO | | | 0046 7633 | 33 | | MOV | @RO,#WARM3 | of the second s | | 0048 08 | 34 | | INC | R0 | | | 0049 76CC | 35 | | MOV | @RO,#WARM4 | ; | | 004B | 36 | INIT: | | eno, ilinatia | ; continue with the application | | | 37 | | | | , continue with the application | | | 38 | END | | | | | | 30 | ши | | | | | ASSEMBLY COMPLETE, 0 | ERRORS | FOIND | | | | | THE STATE OF S | Dittort | o i cond | | | | | COLD | | C | ADDR 0 | 03CH | | | INIT | • • • | | | 04BH | | | MAIN | | | | | | | START | • • • • | | | 026H<br>000H NOT USED | | | WARM | | | | | | | | | • • • | | 030H | | | WARM1 | • • • • | • • • | | 055H | | | WARM2 | • • • | | | 0AAH | | | WARM4 | | • • • | | 033н | | | | | • • • | | 0CCH | | | WARMBT | | | NUMB 0 | 000н | | **AN440** ### Author: Greg Goodhue The following program allows an 80C51 family microcontroller to load most of its code into a RAM over a serial link after power up and execute out of the RAM for normal operation. This can allow a final product to have firmware updates done by a simple diskette mailing. Such a program is often called a "bootstrap loader". For this example, it is assumed that the code download is done via a serial communication link, although the program could be adapted to other forms of download. The comments at the beginning of the listing are intended to document the program and its use completely. An additional comment would be that any static routines (low level routines that are unlikely to change over time) can probably be put into the permanent program memory (on-chip or off-chip ROM or EPROM) along with the bootstrap loader to save program RAM space for other things. The source code file for this program is available for downloading from the Philips computer bulletin board system. This system is open to all callers, operates 24 hours a day, and can be accessed with modems at 2400, 1200, and 300 baud. The telephone numbers for the BBS are: (800) 451-6644 (in the U.S. only) or (408) 991-2406. ### BASIC DIAGRAM OF RAM CONNECTIONS FOR THE BOOT LOADER **AN440** ``` Bootstrap Loader for Hexadecimal Files written by G. Goodhue, Philips Electronics ; This program allows downloading a hexadecimal program file over an ; asynchronous serial link to a code RAM in an 80C51 system. The downloaded ; code may then be executed as the main program for the system. This technique ; may be used in a system that normally connects to a host PC so that the code ; may come from a disk and thus be easily updated. The system RAM must be ; wired to the 80C51 system so that it appears as both data and program memory ; (wire the RAM normally, but use the logical AND of RD and PSEN for the ; output enable.) ; To use the bootstrap program, an Intel Hex file is sent through the serial ; port in 8-N-1 format at 9600 baud. The baud rate and format may be altered ; by making small changes in the serial port setup routine (SerStart). ; Note that there is no hardware handshaking (e.g. RTS/CTS or XON/XOFF) ; implemented between the host and the bootstrap system. This was done to keep ; the protocol between the two systems as simple as possible. ; Since the bootstrap program does not echo the data file, there is no chance ; of an overrun unless the 80C51 is running very slowly and/or the ; communication is very fast. An 80C51 running at 11.0592 MHz (the most ; commonly used frequency in systems with serial communication) will be able ; to easily keep up with 38.4K baud communication without handshaking. ; The download protocol for this program is as follows: - When the bootstrap program starts up, it sends a prompt character ("=") up the serial link to the host. - The host may then send the hexadecimal program file down the serial link. At any time, the host may send an escape character (1B hex) to abort and restart the download process from scratch, beginning from the "=" prompt. This procedure may be used to restart if a download error occurs. - At the end of a hex file download, a colon (":") prompt is returned. If an error or other suspicious circumstance occurred, a flag value will also be returned as shown below. The flag is a bit map of possible conditions and so may represent more than one problem. If an error occurs, the bootstrap program will refuse to execute the downloaded program. Exception codes: 01 - non-hexadecimal characters found embedded in a data line. 02 - bad record type found. 04 - incorrect line checksum found. 08 - no data found. 10 - incremented address overflowed back to zero. 20 - RAM data write did not verify correctly. - If a download error occurs, the download may be retried by first sending an escape character. Until the escape is received, the bootstrap program will refuse to accept any data and will echo a question mark ("?") for any character sent. - After a valid file download, the bootstrap program will send a message containing the file checksum. This is the arithmetic sum of all of the DATA bytes (not addresses, record types, etc.) in the file, truncated to 16 bits. This checksum appears in parentheses: "(abcd)". Program execution may then be started by telling the bootstrap program the correct starting address. The format for this is to send a slash ("/") followed by the address in ASCII hexadecimal, followed by a carriage return. Example: "/8A31<CR>" ``` **AN440** ``` - If the address is accepted, an at sign ("@") is returned before executing the jump to the downloaded file. ; The bootstrap loader can be configured to re-map interrupt vectors to the ; downloaded program if jumps to the correct addresses are set up. For ; instance, if the program RAM in the system where this program is to be used ; starts at 8000 hexadecimal, the re-mapped interrupts may begin at 8003 for ; external interrupt 0, etc. $Title(Bootstrap Loader for Hexadecimal Files) $Date(04-13-92) $MOD51 Definitions EQU 0Ah ; Line Feed character. CR EQU 0Dh ; Carriage Return character. ESC EOU 1Bh ; Escape character. StartChar EOU ; Line start character for hex file. 1.1 Slash EOU 1/1 ; Go command character. Skip EQU 13 ; Value for "Skip" state. Ch DATA 0Fh ; Last character received. State DATA 10h ; Identifies the state in process. DataByte DATA 11h ; Last data byte received. ByteCount DATA 12h ; Data byte count from current line. HighAddr DATA 13h ; High and low address bytes from the LowAddr DATA 14h current data line. RecType DATA 15h ; Line record type for this line. ChkSum DATA 16h ; Calculated checksum received. HASave DATA 17h ; Saves the high and low address bytes LASave DATA 18h from the last data line. FilChkHi DATA 19h ; File checksum high byte. FilChkLo DATA 1Ah ; File checksum low byte. Flags DATA 20h ; State condition flags. HexFlag BIT Flags.0 ; Hex character found. EndFlag BIT Flags.1 ; End record found. DoneFlag BIT Flags.2 ; Processing done (end record or some ; kind of error. EFlags DATA 21h ; Exception flags. ErrFlag1 BIT EFlags.0 ; Non-hex character embedded in data. ErrFlag2 BIT EFlags.1 ; Bad record type. ErrFlag3 BIT EFlags.2 ; Bad line checksum. ErrFlag4 BIT EFlags.3 ; No data found. ErrFlag5 BIT EFlags.4 ; Incremented address overflow. ErrFlag6 BIT EFlags.5 Data storage verify error. DatSkipFlag BIT Flags.3 ; Any data found should be ignored. ``` AN440 ``` Reset and Interrupt Vectors ; The following are dummy labels for re-mapped interrupt vectors. The ; addresses should be changed to match the memory map of the target system. 8003h ; Remap address for ext interrupt 0. T0Int EOU 800Bh ; Timer 0 interrupt. 8013h ExInt1 EQU ; External interrupt 1. T1Int. EQU 801Bh ; Timer 1 interrupt. SerInt ; Serial port interrupt. EQU 8023h ORG 0000h LJMP Start ; Go to the downloader program. ; The following are intended to allow re-mapping the interrupt vectors to the ; users downloaded program. The jump addresses should be adjusted to reflect ; the memory mapping used in the actual application. ; Other (or different) interrupt vectors may need to be added if the target ; processor is not an 80C51. 0003h T<sub>u</sub>TMP ExInt0 ; External interrupt 0. RETI ORG 000Bh ; Timer 0 interrupt. T.,TMP T0Int RETI ORG 0013h ; External interrupt 1. LJMP ExInt1 RETI ORG 001Bh LJMP T1Int ; Timer 1 interrupt. RETI ORG 0023h LJMP SerInt ; Serial port interrupt. Reset and Interrupt Vectors } Start: ; Turn off all interrupts. SP,#5Fh ; Start stack near top of '51 RAM. MOV ACALL SerStart ; Setup and start serial port. ACALL CRLF ; Send a prompt that we are here. MOV A, #'=' "<CRLF> =" ACALL PutChar ACALL HexIn ; Try to read hex file from serial port. ACALL ErrPrt ; Send a message for any errors or warnings that were noted. MOV A, EFlags ; We want to get stuck if a fatal HexOK error occurred. JZ A.#'?' MOV ErrLoop: ; Send a prompt to confirm that we ACALL PutChar are 'stuck'. " ? " ACALL GetChar ; Wait for escape char to flag reload. SJMP ErrLoop HexOK: EFlags, #0 MOV ; Clear errors flag in case we re-try. ACALT. GetChar ; Look for GO command. CJNE A, #Slash, HexOK ; Ignore other characters received. ACALL GetByte ; Get the GO high address byte. JTB ErrFlag1, HexOK ; If non-hex char found, try again. MOV HighAddr, DataByte; Save upper GO address byte. ACALL ; Get the GO low address byte. JB ErrFlag1, HexOK ; If non-hex char found, try again. LowAddr, DataByte ; Save the lower GO address byte. ACALL GetChar ; Look for CR. CJNE A, #CR, HexOK ; Re-try if CR not there. ``` AN440 ``` ; All conditions are met, so hope the data file and the GO address are all correct, because now we're committed. A,#'@' MOV ; Send confirmation to GO. " @ " ACALL PutChar JNB TI,$ ; Wait for completion before GOing. PUSH LowAddr ; Put the GO address on the stack, PUSH HighAddr ; so we can Return to it. RET ; Finally, go execute the user program! Hexadecimal File Input Routine HexIn: CLR ; Clear out some variables. MOV State, A MOV Flags, A MOV HighAddr, A MOV LowAddr, A MOV HASave, A MOV LASave, A MOM ChkSum, A MOV FilChkHi, A VOM FilChkLo, A MOV EFlags, A SETB ErrFlag4 ; Start with a 'no data' condition. StateLoop: ACALL GetChar ; Get a character for processing. ACALL ; Convert ASCII-hex character to hex. MOV ; Save result for later. Ch, A ACALL GoState ; Go find the next state based on this char. JNB DoneFlag, StateLoop; Repeat until done or terminated. ACALL PutChar ; Send the file checksum back as MOV A,#'(' ; confirmation. " (abcd) " ACALL PutChar VOM A, FilChkHi ACALL PrByte MOV A, FilChkLo ACALL PrByte A,#')' MOV ACALL PutChar ACALL CRLF ; Exit to main program. ; Find and execute the state routine pointed to by "State". MOV GoState: A, State ; Get current state. ANL A,#OFh ; Insure branch is within table range. RL Α ; Adjust offset for 2 byte insts. DPTR, #StateTable MOV JMP @A+DPTR ; Go to appropriate state. StateTable: AJMP StWait ; 0 - Wait for start. A.TMP ; 1 - First nibble of count. StLeft AJMP StGetCnt ; 2 - Get count. AJMP ; 3 - First nibble of address byte 1. AJMP StGetAd1 ; 4 - Get address byte 1. AJMP ; 5 - First nibble of address byte 2. StLeft A.TMP StGetAd2 ; 6 - Get address byte 2. AJMP StLeft ; 7 - First nibble of record type. AJMP StGetRec ; 8 - Get record type. AJMP StLeft ; 9 - First nibble of data byte. AJMP ; 10 - Get data byte. StGetDat AJMP StLeft ; 11 - First nibble of checksum. AJMP StGetChk ; 12 - Get checksum. A.TMP StSkip ; 13 - Skip data after error condition. AJMP BadState ; 14 - Should never get here. AJMP BadState ; 15 - " ``` AN440 ``` ; This state is used to wait for a line start character. Any other characters received prior to the line start are simply ignored. StWait. MOV A, Ch ; Retrieve input character. CJNE A, #StartChar, SWEX ; Check for line start. INC State ; Received line start. SWEX: RET ; Process the first nibble of any hex byte. StLeft: MOV A, Ch ; Retrieve input character. JNB HexFlag, SLERR ; Check for hex character. ANT. A,#OFh ; Isolate one nibble. SWAP ; Move nibble too upper location. MOV DataByte, A ; Save left/upper nibble. INC State ; Go to next state. RET ; Return to state loop. SLERR: SETB ErrFlag1 ; Error - non-hex character found. SETB DoneFlag ; File considered corrupt. Tell main. RET ; Process the second nibble of any hex byte. StRight: VOM ; Retrieve input character. TNB HexFlag, SRERR ; Check for hex character. ANL A, #0Fh ; Isolate one nibble. ORL A, DataByte ; Complete one byte. MOV DataByte, A ; Save data byte. ADD A, ChkSum ; Update line checksum, MOV ChkSum, A and save. RET ; Return to state loop. SRERR: SETB ErrFlag1 ; Error - non-hex character found. SETB DoneFlag ; File considered corrupt. Tell main. RET ; Get data byte count for line. StGetCnt: ACALL StRight ; Complete the data count byte. MOV A, DataByte MOV ByteCount, A INC State ; Go to next state. RET ; Return to state loop. ; Get upper address byte for line. StGet Ad1 · ACALL StRight ; Complete the upper address byte. MOV A.DataByte MOV HighAddr, A ; Save new high address. INC State ; Go to next state. RET ; Return to state loop. ; Get lower address byte for line. StGetAd2: ACALL StRight ; Complete the lower address byte. MOV A, DataByte MOV LowAddr, A ; Save new low address. TNC State ; Go to next state. RET ; Return to state loop. ; Get record type for line. StGetRec: ACALL StRight ; Complete the record type byte. MOM A, DataByte MOV RecType, A ; Get record type. JZ SGRDat ; This is a data record. CINE A, #1, SGRErr ; Check for end record. SETB EndFlag ; This is an end record. SETB DatSkipFlag ; Ignore data embedded in end record. MOV State, #11 ; Go to checksum for end record. SJMP SGREX ``` ``` SGRDat: TNC State ; Go to next state. SGREX: RET ; Return to state loop. SGRErr. SETB ErrFlag2 ; Error, bad record type. SETB DoneFlag ; File considered corrupt. Tell main. RET ; Get a data byte. StGetDat: ACALL ; Complete the data byte. JB DatSkipFlag,SGD1 ; Don't process the data if the skip flag is on. ACALL. Store ; Store data byte in memory. MOV A, DataByte ; Update the file checksum, A, FilChkLo ; which is a two-byte summation of MOV FilChkLo, A ; all data bytes. CLR ADDC A, FilChkHi MOV FilChkHi.A MOV A, DataByte SGD1: DJNZ ByteCount, SGDEX ; Last data byte? INC State ; Done with data, go to next state. SJMP SGDEX2 SGDEX . DEC State ; Set up state for next data byte. SGDEX2: RET ; Return to state loop. ; Get checksum. StGetChk: ACALL StRight ; Complete the checksum byte. EndFlag, SGC1 JNB ; Check for an end record. SETR DoneFlag ; If this was an end record, SJMP SGCEX ; we are done. SGC1: MOV A, ChkSum ; Get calculated checksum. JNZ ; Result should be zero. MOV ChkSum, #0 ; Preset checksum for next line. MOV State,#0 ; Line done, go back to wait state. MOV LASave,LowAddr ; Save address byte from this line for MOV HASave, HighAddr later check. SGCEX: RET ; Return to state loop. SGCErr: SETB ErrFlag3 ; Line checksum error. SETB DoneFlag ; File considered corrupt. Tell main. RET ; This state used to skip through any additional data sent, ignoring it. ; Return to state loop. ; A place to go if an illegal state comes up somehow. MOV BadState: State, #Skip ; If we get here, something very bad happened, so return to state loop. ; Store - Save data byte in external RAM at specified address. Store: MOV DPH, HighAddr ; Set up external RAM address in DPTR. MOV DPL, LowAddr MOV A,DataByte @DPTR,A MOVX ; Store the data. MOVX A,@DPTR ; Read back data for integrity check. A, DataByte, StoreErr ; Is read back OK? CJNE CLR ErrFlag4 ; Show that we've found some data. TNC ; Advance to the next addr in sequence. DPTR MOV HighAddr, DPH ; Save the new address MOV LowAddr, DPL CLR A, HighAddr, StoreEx; Check for address overflow CJNE CJNE A, LowAddr, StoreEx; (both bytes are 0). SETB ; Set warning for address overflow. ``` AN440 ``` StoreEx: RET StoreErr: SETB ErrFlag6 ; Data storage verify error. SETB DoneFlag ; File considered corrupt. Tell main. RET Subroutines ; Subroutine summary: ; SerStart - Serial port setup and start. ; GetChar - Get a character from the serial port for processing. ; GetByte - Get a hex byte from the serial port for processing. ; PutChar - Output a character to the serial port. - See if char in ACC is ASCII-hex and if so convert to hex nibble. ; HexAsc - Convert a hexadecimal nibble to its ASCII character equivalent. ; ErrPrt - Return any error codes to our host. - output a carriage return / line feed pair to the serial port. ; PrByte - Send a byte out the serial port in ASCII hexadecimal format. ; SerStart - Serial port setup and start. A, PCON SerStart: MOV ; Make sure SMOD is off. CLR ACC.7 MOV PCON, A MOV TH1,#0FDh ; Set up timer 1. MOV TL0, #0FDh MOV TMOD, #20h MOV TCON, #40h MOV SCON, #52h ; Set up serial port. ; GetByte - Get a hex byte from the serial port for processing. GetByte: GetChar ; Get first character of byte. ACALL AscHex ; Convert to hex. MOV Ch.A ; Save result for later. ACALL StLeft ; Process as top nibble of a hex byte. ACALL GetChar ; Get second character of byte. ACALL AscHex ; Convert to hex. ; Save result for later. MOV Ch, A ACALL StRight ; Process as bottom nibble of hex byte. RET ; GetChar - Get a character from the serial port for processing. GetChar: JNB RT.S ; Wait for receiver flag. ; Clear receiver flag. CLR MOV A, SBUF ; Read character. CJNE A, #ESC, GCEX ; Re-start immediately if Escape char. T.,TMP Start GCEX: RET ; PutChar - Output a character to the serial port. PutChar: JNB TI,$ ; Wait for transmitter flag. CLR TI ; Clear transmitter flag. MOV SBUF, A ; Send character. ; AscHex - See if char in ACC is ASCII-hex and if so convert to a hex nibble. Returns nibble in A, HexFlag tells if char was really hex. The ACC is not altered if the character is not ASCII hex. Upper and lower case letters are recognized. ``` AN440 ``` A, #'0', AH1 AscHex: CJNE ; Test for ASCII numbers. JC AH1: AHBad ; Is character is less than a '0'? A, #'9'+1, AH2 ; Test value range. CJNE AH2: AHVal09 ; Is character is between '0' and '9'? ; Test for upper case hex letters. CJNE A, #'A', AH3 ; Is character is less than an 'A'? AH3: JC AHBad CJNE A, #'F'+1, AH4 ; Test value range. AH4: JC AHValAF ; Is character is between 'A' and 'F'? CJNE A, #'a', AH5 ; Test for lower case hex letters. AH5: JC AHBad ; Is character is less than an 'a'? CJNE A, #'f'+1, AH6 ; Test value range. AH6: JNC ; Is character is between 'a' and 'f'? AHBad CLR C SUBB A, #27h ; Pre-adjust character to get a value. SJMP AHVal09 ; Now treat as a number. AHBad: CLR HexFlag ; Flag char as non-hex, don't alter. SJMP AHEX ; Exit AHValAF: CLR C SUBB A.#7 ; Pre-adjust character to get a value. AHVal09: CLR С A,#'0' SUBB ; Adjust character to get a value. SETB HexFlag ; Flag character as 'good' hex. AHEX: RET ; HexAsc - Convert a hexadecimal nibble to its ASCII character equivalent. HexAsc: ANL A,#0Fh ; Make sure we're working with only one nibble. CJNE A, #OAh, HA1 ; Test value range. HA1 - .TC HAVal09 ; Value is 0 to 9. ADD A,#7 ; Value is A to F, extra adjustment. HAVal09: ADD A, #'0' ; Adjust value to ASCII hex. RET ; ErrPrt - Return an error code to our host. MOV A,#':' ErrPrt: ; First, send a prompt that we are CALL PutChar still here. MOV A, EFlags ; Next, print the error flag value if JZ ErrPrtEx ; it is not 0. CALL PrByte ErrPrtEx: RET ; CRLF - output a carriage return / line feed pair to the serial port. A,#CR CRLF: MOV CALL PutChar MOV A, #LF CALL PutChar ; PrByte - Send a byte out the serial port in ASCII hexadecimal format. PrByte: PUSH ACC ; Print ACC contents as ASCII hex. SWAP CALL HexAsc ; Print upper nibble. CALL PutChar POP ACC CALL HexAsc ; Print lower nibble. CALL PutChar RET ``` 620 END Philips Semiconductors Application note ### IEEE Micro Mouse using the 87C751 microcontroller **AN443** Author: Tracy Ching ### DESCRIPTION Micro Mouse is an IEEE contest first proposed by the author of IEEE Spectrum in 1977. It consists of an autonomous robot known as a "mouse" which navigates through a maze of 256 two-inch-high, seven-inch squares in a 16 x 16 arrangement. The robot is self powered and has no knowledge of the maze configuration prior to releasing it in the maze. The first time it is released into the maze, its prime objective is to find a path from the starting square which is located in a corner of the maze to the destination square which can be located in the center or a different corner depending on competition level. The destination square for the advanced level can be found only by using a smart algorithm which will make the mouse gravitate towards the center without becoming lost. The destination square for a novice contest can be found by using a wall hugging algorithm. The analogy for this algorithm is to imagine a blind person holding their right hand out against a wall and following the walls until they reach the destination. A maximum of ten runs or 15 minutes is given to each mouse. Leaving the starting square constitutes one run. The mouse with the fastest run time from the starting square to the destination square The contest is held with different competition levels for novices and advanced. The novice level is typically held for college students trying to exercise newly acquired hardware and software skills, whereas the advanced level encompasses international talent and may require the implementation of a proportional integral derivative (PID) controller in software to utilize commutated or brushless DC motors and complex navigation algorithms. ### **DESIGN OBJECTIVES** Several design objectives were as follows: minimize weight, minimize part size and count, minimize power consumption which allows the use of smaller and lighter batteries, minimize cost and maximize speed. The main objective was to keep the total weight at a minimum to obtain the fastest acceleration from the stepper motors and to reduce wheel slippage during deceleration and turning. The objectives are inter-related such that changing one will affect the other. Hence, having a low part count means lighter weight, faster acceleration and lower cost. A typical mouse may consist of a microcontroller with supporting memory and GLU logic to interface the motor controllers and sensors. The 87C751 is suitable for this application with its small size. The need for external RAM is eliminated by using the internal RAM to store minimum maze information suitable for the novice level. Nickel cadmium batteries are used because of the cost, size and power density obtainable versus other battery types. Nickel metal hydride was not available during development but would be a good choice over nickel cadmium batteries. ### The 87C751 Microcontroller The 87C751 is an 8-bit microcontroller based on the 8051 microcontroller family. It is code compatible with the exception of the MOVX, LJMP, and LCALL instructions. The MOVX instruction and external memory accesses are not supported. LJMP and LCALL instructions are not needed since AJMP and ACALL can reach the entire program memory range (2k bytes) of the 751. The 87C751 contains a 2k × 8 EPROM, a 64 × 8 RAM, 19 I/O lines, a 16 bit auto-reload counter/timer, a fixed rate timer, a five source fixed priority interrupt structure, a bidirectional Inter-Integrated circuit (I2C) bus interface, and an internal oscillator. The 87C751 comes in an erasable quartz package (87C751), one time programmable (87C751), and mask ROM (83C751). ### HARDWARE DESCRIPTION Figure 1 is a schematic diagram of the mouse. The stepper motors are 4 volts 0.95 amperes per coil giving about 14 oz-inches of torque. Each motor is driven by an Allegro UCN-5804B unipolar stepper motor translator/driver which contains the sequencing logic and high current darlington outputs. The sequencing logic only requires clock, direction of rotation, and output enable signals from the 87C751 which relieves the chore of having to cycle through a sequencing table for both motors therefore reducing code size. Fast recovery diodes are used to protect the darlington outputs from negative voltage due to motor winding flyback The infrared (IR) emitters are Optek OP-240A. The sensors are Optek OPL-560-OC which have a built-in light amplifier and TTL open collector output. Each sensor bank is enabled via a high side P-channel MOSFET. A 74LS04 (U4) is used to drive the P-channel MOSFET. Data from each bank of eight IR sensors is fed into port 3. By using open collector output sensors, the need for latching the data using a 3-State buffer is eliminated. Port pins P0.0 and P0.1 are used for enabling either the left or right sensor bank via the 74LS04 (U4) and the MOSFETs. Each sensor bank hangs over the two inch high walls whereby the light emitted from the OP-240 is reflected into the OPL-560-OC if a wall is present. Two sensor pairs in the middle of the array are typically sensing the presence of a wall and the remaining sensors are used for guidance to keep the mouse running parallel to the walls. A 74LS573 connected to port 3 which latched data into eight LEDs was used in the debugging process. P1.7 was used on the latch signal for the 74LS573. Since the eight LEDs and latch were not needed for the final product, they were removed thus reducing weight and battery drain. LEDs D1 and D2 were also used in the debugging process and are currently used for visual feedback when selecting options during operation. Power for the digital circuitry is fed by an 8.4 volt NiCAD battery pack, packaged in a 9 volt battery case, via a 7805 regulator. The circuit can run constantly with the sensors taking "snapshots" of the walls intermittently for at least 30 minutes satisfying the 15 minute maximum requirement. Power for the motors is fed by four "A" size NiCAD cells which have enough energy to run the motors for 15 minutes before becoming useless at about 1 volt per cell. ### **TASK PRIORITIES** Several tasks take place during program execution which are as follows in order of importance: pulsing the stepper motors according to a velocity profile table, gathering sensor data, deciding whether to accelerate, decelerate, turn left or right. In-line coding is used to avoid calling subroutines that cause the program counter to be pushed onto the stack and use valuable RAM for the turn decisions. Interrupt subroutines are an exception. Interrupt timer 0 (T0) vectors to the routine which supplies a pulse to the stepper motor drivers. This is the most important task because the stepper motors require a smooth train of pulses in order to prevent jerky or sporadic motions. Thus, T0 must have the highest priority and must not be interrupted. Although timer 0 is a 16 bit timer, only eight bits are used with the higher byte set to FFH. T0 takes care of pulsing the left and right motor drivers at different times by using two external registers which are used as prescalers. Each motor can be assigned a different prescale value via the assigned register in order to step each motor at a different step rate. AN443 The velocity profile table for T0 was designed using a spreadsheet program with visual graphing. This aided the ability to derive an exponential table for the fastest stepper motor acceleration using qualitative observations. The first part of the in-line code contains the routine to accelerate the mouse from a stopped position. A pointer for each motor is incremented until the end of the velocity profile table is reached. During acceleration, the left and right sensors are strobed and stored after each step caused by T0. The routine that strobes the sensors for wall data returns several results through the use of flags. The routine first stores the sensor data in registers. This information is used to determine if the sensor array or mouse is too far right, left, or aligned in a square and to set the corresponding flags. It also returns the presence of a front wall using the innermost sensor pairs. The deceleration routine is similar to the acceleration routine except the pointers decrement through the velocity profile table skipping a few values each time. Deceleration uses less steps than acceleration. The routine which decides whether to continue acceleration, deceleration, or turn left or right keeps track of step count or position of the mouse within a square in order to store wall information at the proper time. After the previous routines have stored the data for the front, left, and right walls, a decision is obtained. If the mouse is not in a back-up mode, the wall information, status of the back-up flag and left/right algorithm flag forms an offset byte. If the mouse is in a back-up mode, the decision from above plus the previous decision on the stack is used to form the offset byte. This offset is stored in the accumulator. The decision which contains the direction to turn is obtained using the MOVC instruction which points to the table using the data pointer. The logic table is shown in Tables 1 and 2 below. External interrupt 0 (INT0) vectors to the routine which brings the mouse to a halt. INT0 subroutine disables T0, sets output enable high on the stepper motor drivers, and sets the return address for the program counter to 0000H. This causes the mouse to restart program execution without losing the internal RAM. Table 1. Logic Table: Non-Back-Up Mode | (1) | (2) | (3) | (4) | |-----|---------|-----|-------------------| | R | NONE | R | push R onto stack | | R | F | R | push R onto stack | | R | R | s | push S onto stack | | R | R, F | L | push L onto stack | | R | L | R | push R onto stack | | R | L, F | R | push R onto stack | | R | L, R | s | ignore | | R | L, R, F | 180 | turn on B-U flag | | L | NONE | L | push L onto stack | | L | F | L | push L onto stack | | L | R | L | push L onto stack | | L | R, F | L | push L onto stack | | L | L | S | push S onto stack | | L | L, F | R | push R onto stack | | L | L, R | S | ignore | | L | L, R, F | 180 | turn on B-U flag | ### NOTES: Abbreviations used: R = right L = left F = front S = straight B-U = back-up flag stack = RAM used for storing decisions (not for the program counter) Non back-up mode: - (1) wall hugging algorithm (user selected) - (2) walls surrounding present square - (3) direction to turn - (4) operations to perform Table 2. Logic Table: Back-Up Mode | (1) | (2) | (3) | (4) | |-----|-----|-----|---------------------------------| | R | R | R | push S onto stack,<br>clear B-U | | R. | ٦ | L | pop stack only | | R | Ø | S | push L onto stack,<br>clear B-U | | L | R | R | pop stack only | | L | L | L | push S onto stack,<br>clear B-U | | L | S | S | push R onto stack,<br>clear B-U | | S | R | R | push L onto stack,<br>clear B-U | | S | L | L | push R onto stack,<br>clear B-U | | S | S | S | pop stack only | #### NOTES: Abbreviations used: R = right L = left F = front S = straight B-U = back-up flag stack = RAM used for storing decisions (not for the program counter) Back-up mode: - (1) previous decision from top of stack - (2) decision from the above table for this current square - (3) direction to turn (should be equal to (2) - (4) operations to perform (all operations require lowering the stack by one before pushing data) Application note ### IEEE Micro Mouse using the 87C751 microcontroller AN443 ### **OPERATION** #### Reset True reset is accomplished only during power on. After completing the maze, the operator brings the mouse to a stop using the start/stop switch which effectively disables the motors and resets the program counter to 0000H, restarting the mouse's program with the exception that the RAM contains vital maze information. ### Starting/Stopping After power-up, the mouse remains idle with the motors and sensors disabled, awaiting an interrupt from switch SW1. The first time the switch is pressed, the mouse will start. The second time the switch is pressed, the mouse will stop and the cycle repeats. ## Selecting right or left wall hugging After power on reset, the program defaults to right wall hugging. Pressing switch SW2 will cause the mouse to follow the left walls. If it is pressed again, it will follow the right walls—toggling between the left and right wall hugging algorithm each time it is pressed. ### Increasing motor speed After completing the first run, pressing switch SW2 causes the timer value to increase by an index of one, increasing the speed of the motors. This allows the mouse to be run at increasing speeds each run in order to attain the fastest possible time before crashing into a wall or incurring a condition in the stepper motors called "pull-out". Pull-out is a condition wherein the fields are changing in the coils faster than the rotor can maintain synchronism with the coils, causing the rotor to stall. ### SOFTWARE LIMITATIONS The 87C751 has 64 bytes of RAM. The program requires 31 bytes of RAM leaving 33 bytes for storing decisions. One hundred thirty two decisions can be stored in 33 bytes of RAM since four decisions are stored per byte. Although there are 16 times 16 squares with possibly 256 decisions to be made, this condition is not very probable since every square typically is not made into a turning point. Long straight ways are used as well as turning points. The probability that the RAM will fill to the maximum capacity is very slim in the novice level where there are typically 50 decisions to be made. Hence, RAM which can hold 132 decisions is adequate but not infallible. ### **FUTURE ENHANCEMENTS** Although the 87C751 has minimal RAM, I<sup>2</sup>C RAM could be easily added by switching the MOSFET drivers using the LED port pins and placing the I<sup>2</sup>C RAM on port pins P0.0 and P0.1. This would allow the implementation of a full mapping algorithm thus allowing entry to the advanced class. The code size for the I<sup>2</sup>C routines and recursive algorithm to find the center of the maze would add about 800 bytes more of code. Since some of the code for the novice class would be eliminated, it would bring the total code size to less than 2k bytes. A few maze solving algorithms have been implemented successfully on other mice. These are the flooding or Bellman's algorithm, backtracking algorithm and others. The first two algorithms are recursive, thus the code sizes are quite small. Another added feature would be the ability to execute a rounded turn rather than pivot. This requires a more complex navigation scheme and velocity profiler to make the motors turn at differing speeds in order to make the rounded turn. In addition to the enhancements aforementioned, methods to track a wall through the use of an A/D converter which measures the reflectivity strength from infrared sensors pointing at the sides of the walls can also be implemented on the I<sup>2</sup>C bus. This would eliminate the array of sensors hanging in front of the mouse on top of the walls thus decreasing the weight. #### CONCLUSION The 87C751 microcontroller provides the required computing resources and I/O ports necessary to control a robotics device known as a "Micro Mouse". The I<sup>2</sup>C interface allows for an abundance of variations on this robotics device. Figure 1. Schematic Diagram of the Maze Mouse | MCS-51 MACRO ASSE | EMBLER | 751MAIN | | 04/16/92 PAGE 1 | |-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|----------------------------------------------------------------| | LOC OBJ | LINE | SOURCE | | | | DOC ODO | 1 | | ****** | ****** | | | 2 | • | | .0 started 9-27-91 * | | | 3 | | | .3 finished 4-16-92 * | | | 4 | The state of s | nd programming b | | | | 5 | | | for use as in-line coding * | | | 6 | | | abroutines (S.R.) * | | | 7 | | | ****** | | | 8 | · | | | | | | +1 \$include | (751.equ) | | | | | | | | | | =1 10<br>=1 11 | | | | | | =1 11<br>=1 12 | | equ 00 | ;used for ind addr of regs | | | | | equ 01 | ; pointer for storing map of maze | | | | , | | ; decide storage-local, | | | =1 14<br>=1 15 | • | | ;do180, turn90 use it | | | | | | ; snapshot R wall storage | | | =1 16 | | - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 | | | | =1 17 | | | ;snapshot L wall storage<br>;store_val, decel, int 1, gen purp | | | =1 18 | • | equ 06<br>equ 07 | | | | =1 19 | | equ 07 | ;pause setting, gen purp | | | =1 20<br>=1 21 | | eau 08h | ;step count used by decide | | | =1 21<br>=1 22 | | • | | | | =1 22<br>=1 23 | | | ;<br>;storage for 74LS373 debug data leds | | | =1 23<br>=1 24 | | | ;count for wall, step count | | | =1 24<br>=1 25 | | - | ; value to be used in the isr | | | =1 25<br>=1 26 | . — | | | | | =1 26<br>=1 27 | | | ;<br>;points at accel table | | | =1 27<br>=1 28 | | • | ; | | | =1 26<br>=1 29 | <del></del> - | equ 0fh<br>equ 10h | ; points to the specific two bits in map ptr | | | =1 29 $=1$ 30 | · | 11h | , points to the specific two bits in map pt | | | =1 30 | · · · · · · · · · · · · · · · · · · · | 12h | | | | =1 31 $=1$ 32 | | 13h | | | | =1 33 | · · · · · · · · · · · · · · · · · · · | 14h | | | | =1 33<br>=1 34 | · · · · · · · · · · · · · · · · · · · | 15h | | | | =1 34 | | 16h | | | | =1 36 | | 17h | | | | =1 30 | · | 1/11 | | | | =1 38 | | 87H | | | | =1 39 | | 0C7H | | | | =1 40 | · · · · · · · · · · · · · · · · · · · | 8bh | | | | =1 41 | | 8dh | | | | =1 42 | - | oun | | | | =1 43 | | | | | | =1 43 | | tions they are | erased after every restart | | 0020 | =1 49 | | equ 20h | ; sens flag reg | | | =1 45 | | bit 20h.0 | | | | =1 47 | . <del>-</del> | bit 20h.1 | • • • • • • • • • • • • • • • • • • • • | | 0001 | =1 48 | | bit 20h.2 | | | | =1 48 | | bit 20h.2 | | | 0003<br>0004 | =1 45 | _ | bit 20h.3 | | | 0004 | -T 2( | J L_Wall | DIC 2011.4 | , ITOME wall present, snapshot storage | AN443 | MCS-51 MAG | CRO ASSE | MBLER | 751MAIN | | | 04/16/92 PAGE 2 | |------------|-----------------------------------------|----------|---------------------|---------------|----------------|----------------------------------------------------------------| | LOC OBJ | | LINE | SOURCE | | | | | 0005 | = | 1 51 | aligned | bit | 20h.5 | ;sensors detect OK straightness | | 0006 | = | 1 52 | far_r | bit | 20h.6 | ;used to sync step count | | 0007 | 1 = | 1 53 | far_l | bit | 20h.7 | ;ditto - left | | | 1 = | 1 54 | | e in the same | | | | 8000 | = | | r_turn | bit | 21h.0 | ; decide sets this for turn S.R. | | 0009 | = | | l_turn | bit | 21h.1 | ;ditto | | 000A | = | | s_s_int | bit | 21h.2 | ;start stop bit | | 000B | - = | | time_int | bit | 21h.3 | ;timer 0 int has occurred | | 000C | = | | r_int | bit | 21h.4 | ;r motor was stepped | | 000D | = | | 1_int | bit | 21h.5 | ;1 mot | | 000E | =: | | slow_r | bit | 21h.6 | ;make int_0 incr timer flag | | 000F | = = = = = = = = = = = = = = = = = = = = | | slow_l | bit | 21h.7 | ;ditto left | | 0010 | , | | act out | 1. 3 4. | 0.01-0 | | | 0011 | =: | | get_out<br>r_decide | bit | 22h.0 | ;used to flag accel to end so decel can do | | 0011 | = | | l_decide | bit<br>bit | 22h.1 | ;r wall present, decide storage | | 0013 | 1=: | | f_decide | bit | 22h.2<br>22h.3 | ;1 wall present, decide storage | | 0014 | .=: | | make_180 | bit | 22h.4 | ;f wall present, decide storage | | 0015 | = | | prev_r | bit | 22h.4<br>22h.5 | ;decide says do 180<br>;decide uses for detect wall transition | | 0016 | = | 7 1 15 5 | prev_1 | bit | 22h.6 | ; ditto left | | 0017 | =: | | cw180 | bit | 22h.7 | toggle dir of 180 | | | =: | | | 220 | 2211.7 | /coggle dir or 100 | | 0018 | =: | 1 73 | det_L2H | bit | 23h.0 | ;used to detect the low to high wall | | 0019 | =: | 1 74 | look4f | bit | 23h.1 | ;skips to look for front wall | | 001A | =: | 1 75 | back_up | bit | 23h.2 | tells decide that it is backing up | | 001B | =: | 1 76 | look | bit | 23h.3 | start looking at wall | | 001C | =: | 1 77 | count_en | bit | 23h.4 | ; enables step counting | | 001D | =: | 1 78 | skip_decide | bit | 23h.5 | ;TEMPORARY (testing only) | | 001E | =: | L 79 | genp2 | bit | 23h.6 | ;chk R or L sens flag | | 001F | =: | 1 80 | genp1 | bit | 23h.7 | ;gen purpose, watch for conflicts betwx S.R.s | | | =: | L 81 | | | | | | | =3 | L 82 | | | | | | | =1 | | | | | | | | =: | | | e flags t | hat don't | get erased after restarting | | 0020 | =1 | | done | bit | 24h.0 | ;tells the prog that it has gone thru | | 0021 | =1 | | l_r_bit | bit | 24h.1 | ;hug left or right bit, set=left, clr=right | | 0022 | =1 | | temp_bit1 | bit | 24h.2 | ;local bit var | | | =1 | | | | | | | | =1 | | | | | | | 0082 | · =1<br>=1 | | ;hardware defi | | | | | 0082 | =1 | | 1_led | bit | p0.2 | | | 0090 | | | r_led | bit | p1.7 | | | 0081 | =1 | | mot_en<br>r_sens | bit | p1.0 | | | 0080 | =1 | | l_sens | bit<br>bit | p0.1 | | | 0092 | =1 | | r_step | bit | p0.0<br>p1.2 | | | 0091 | =1 | | r_dir | bit | p1.2<br>p1.1 | | | 0094 | =1 | | 1_step | bit | p1.1 | | | 0093 | =1 | | l_dir | bit | p1.4 | | | 0095 | =1 | | s_s_sw | bit | p1.5 | | | 0096 | =1 | | l_r_sw | bit | p1.6 | | | 00B0 | =1 | 102 | sensors | equ | р3 | | | | | 103 | +1 \$include | | 751.tab) | | | | =1 | 104 | ;These are all | | | stants. | | | =1 | 105 | | | | | AN443 | MCS-51 MACRO ASSEMBLER | 751MAIN | | 04/16/92 PAGE 3 | |------------------------------------|--------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LOC OBJ LINE | SOURCE | | | | =1 106 | extrn number | (timer_reload) | | | =1 107 | extrn number | (pivot_speed) | | | =1 108 | extrn number | (acc_steps) | | | =1 109 | extrn number | (half_way) | | | =1 110 | extrn number | (hold_val) | | | =1 111 | extrn number | (dec_acc) | | | =1 112 | extrn number | (decel_steps) | | | =1 113 | extrn number | (decel_decr) | | | =1 114 | extrn number | (steps90) | | | =1 115 | extrn number | (half_90) | | | =1 116 | extrn number | (look90) | | | =1 117 | extrn number | (steps180) | | | =1 118 | extrn number | (half_180) | | | =1 119 | extrn number | (look180) | | | =1 120 | extrn number | (map_org_addr) | | | =1 121 | extrn number | (sens_pat) | | | =1 122 | extrn number | (pause_val) | | | =1 123 | extrn number | (w2nw_cnt) | | | =1 124 | extrn number | (chk4fr) | | | 125 | | K K. | | | 0000 126 | | org 00 | | | 0000 0115 127 | | ajmp main | | | 0003 128 | | org 03 | | | 0003 618D 129 | | ajmp int_0 | | | 000B 130 | | org Obh | | | 000B 6123 131 | | ajmp tim_0 | | | 0013 132 | | org 13h | | | 0013 6164 133 | | ajmp int_1 | | | 134 | | | | | 135 | | | | | 136 | | ****** | ******* | | 137 | | | s. Note that the maze info * | | 138 | | | *** | | 139 | | | ******* | | 140 | | | | | 0015 C220 141 | | clr done | ;start intial run | | 0017 758B00 F 142 | | mov rtl,#timer_relo | | | 001A 758DFF 143 | | mov rth, #0ffh | 1 | | 144 | | 2 2 2 2 | and the state of t | | 001D D281 145 | | setb r_sens | | | 001F D280 146 | | setb l_sens | | | 0021 43907F 147 | | orl p1,#7fh | ;lines high | | 0024 752000 148 | | mov 20h,#0 | ;clear all flags except for | | 0027 752100 149 | | mov 21h, #0 | ; location 24h bits | | 0027 752100 149<br>002A 752200 150 | | mov 22h,#0 | , Toodeton bin brob | | 002A 752200 150 | | mov 23h,#0 | | | | | | ;clear out 10h to 0h ram | | | | mov r0,#10h<br>mov @r0,#0 | ; clears the regs | | 0032 7600 153 | | djnz r0,main_0 | , clears the regs | | 0034 D8FC 154 | | | | | 0036 750125 156 | | alize values | ;start of STACK | | 0036 758125 156 | | mov sp,#25h | | | 0039 7900 F 157 | | | dr;start of mapping memory | | 003B 75A887 158 | | mov ie,#10000111b | ;enable ints | | 003E 300AFD 159 | | jnb s_s_int,\$ | stay here until start pressed | | 160 | ) | | | AN443 | MCS- | 51 MACRO | ASSEME | LER | 751MAIN | | | 04/16/92 PAGE 4 | |------|--------------|--------|------------|-----------------------|-------------|------------------------|----------------------------------------| | LOC | OBJ | | LINE | SOURCE | | | | | | | | 161 | | | | | | | | | 162 | ; * * * * * * * * * * | ***** | ******* | ******* | | | | | 163 | | | | hru the velocity table. * | | | | | 164 | | | | ouse is too close to a wall. * | | | | | 165 | ;******* | ****** | ******* | ******** | | | | | 166 | | | | | | 0041 | 7100 | | 167 | accel: | | acc_table and g | oes from there | | | 7187 | | 168 | | acall | snapshot | | | | A202<br>9215 | | 169 | | mov | c,r_wall | ; check the walls | | | A203 | | 170 | | mov | prev_r,c | | | | 9216 | | 171<br>172 | | mov | c,l_wall | ; for both sides | | | 750841 | | 173 | | mov | prev_1,c | | | | 750E00 | | 174 | acc_aa: | mov | step_count,#65 | ; start at 75stps, sens mid way | | | 750F00 | | 175 | acc_aa. | mov | l_ptr,#0<br>r_ptr,#0 | alon officer | | | 750DFE | | 176 | | mov | r_timr,#0feh | ;clear offsets | | | 750CFE | | 177 | | mov | l_timr,#0feh | even up the timers to step; evenly | | | D28C | | 178 | | setb | tr0 | ; enable timer int | | | | | 179 | | 2002 | C10 | , enable times int | | 005C | 300BFD | | 180 | acc_0: | jnb | time_int,\$ | ;stay here until int happens | | 005F | C20B | | 181 | | clr | time_int | , sou, note dieti inc happens | | 0061 | 71B7 | | 182 | | acall | snapshot | ;get status of too_1 too_r | | | | | 183 | | | | | | | | | 184 | | ;right | routine | | | 0063 | 300C21 | | 185 | | jnb | r_int,acc_1 | ;skip if right hasn't been stepped yet | | 0066 | C20C | | 186 | | clr | r_int | ackn r int | | 0068 | E50F | | 187 | | mov | a,r_ptr | ; check to see if at end of acc | | | B40002 | F | 188 | | cjne | a,#acc_steps,a | cc_1c | | | 0171 | | 189 | | ajmp | acc_1b | | | | 050F | | 190 | acc_1c: | inc | r_ptr | ; point to next accel value | | | 300113 | | 191 | acc_1b: | jnb | too_1,acc_1 | ; if not too left then fall thru | | 0074 | | | 192 | | clr | C | ;subtr halfway from ptr | | | E50F | _ | 193 | | mov | a,r_ptr | | | | 9400 | ·F | 194 | | subb | a,#half_way | ;C set if ptr < half_way | | | E50D | | 195 | | mov | a,r_timr | | | | 4006<br>2400 | | 196 | | jc | acc_1a | | | | F50D | F | 197<br>198 | | add | a,#hold_val | ; slow down even more | | | 0187 | | 199 | | mov | r_timr,a | ;load it back into timer decel value | | | 2400 | F | 200 | acc_1a: | ajmp<br>add | acc_1 | ;get out | | | F50D | - | 201 | dcc_ra. | mov | a,#dec_acc<br>r_timr,a | ;dec_acc used when going fast | | 0005 | 1302 | | 202 | | mov | r_cimir, a | ; load it back into timer decel value | | | | | 203 | | left | routine | | | 0087 | 300D21 | | 204 | acc_1: | jnb | l_int,acc_2 | ;if L hasn't been stepped, skip | | | C20D | | 205 | | clr | l_int | ;ackn l int | | 008C | E50E | | 206 | | mov | a,l_ptr | ; check to see if at end of acc | | 008E | B40002 | F | 207 | | cjne | a, #acc_steps, ac | | | 0091 | 0195 | | 208 | | ajmp | acc_2b | | | 0093 | 050E | | 209 | acc_2c: | inc | l_ptr | ; point to next accel value | | 0095 | 300013 | | 210 | acc_2b: | jnb | too_r,acc_2 | ; if not too right then fall thru | | 0098 | C3 | | 211 | | clr | c | ; subtr halfway from ptr | | | E50E | | 212 | | mov | a,1_ptr | | | | 9400 | F | 213 | nat je flaga i si si | subb | a,#half_way | ;C set if ptr < half_way | | 009D | E50C | | 214 | | mov | a,l_timr | | | | 4006 | | 215 | | | | | | MCS-51 MACRO ASSEMBLER | 751MAIN | | 04/16/92 PAGE 5 | |-------------------------------|-----------------|--------------------------|-------------------------------------------| | | | | | | LOC OBJ LINE | SOURCE | | | | 00A1 2400 F 216 | | add a, #hold_val | ; slow down even more | | 00A3 F50C 217 | | mov l_timr,a | ; load it back into timer decel value | | 00A5 01AB 218 | | ajmp acc_2 | ;get out | | 00A7 2400 F 219 | acc_2a: | add a,#dec_acc | ;dec_acc used when going fast | | 00A9 F50C 220 | | mov l_timr,a | ;load it back into timer decel value | | 8.1 4 S. 11 4 S. 11 4 S. 12 1 | | | | | 222 | acc_2: | | | | 223 | | | | | 224 | | | | | 225 | | ******** | | | 226 | | | It makes the decision to * | | 227 | ; quit accelera | tion, turn left or right | , make a 180 pivot, store * | | 228 | ; a decision, o | r get a decision from th | me stack. * | | 229 | ,********* | ****** | ******* | | 230 | | | | | 231 | ;decide: | | | | 232 | | ;r_turn, l_turn, get_ou | it, make_180 as public bits | | 233 | | ;r_decide, l_decide, f_ | | | 234 | | | rt the decel using a step count | | | | | when it is time to turn. It also | | 236 | ;decide | | a mapping run or a final run. | | 237 | | ;1) look for a wall to | | | 00AB 201853 238 | | jb det_L2H,di_3_1 | ;skip the stuff below if set | | 00AE A215 239 | | mov c,prev_r | | | 00B0 B002 240 | | anl c,/r_wall | ; check for r wall transition | | 00B2 5003 241 | | jnc di_1 | ;if no transition goto di 1 | | 00B4 750800 242 | Section 1 | mov step_count,#0 | start counting | | 00B7 A216 243 | di_1: | mov c,prev_1 | | | 00B9 B003 244 | | anl c,/l_wall | ; check for 1 wall transition | | 00BB 5003 245 | | jnc di_2 | ;if no transition goto di 2 | | 00BD 750800 246 | | mov step_count,#0 | ;start counting | | 247 | di_2: | | | | 248 | | ;2) now detect step co | unt (1986) | | 00C0 E508 249 | | mov a, step_count | ; check to see if | | 00C2 C3 250 | | clryed. c howy | | | 00C3 9454 251 | | subb a,#84 | ; 80 <= steps <= 83 | | 00C5 5013 252 | | jnc di_3 | | | 00C7 E508 253 | | mov a, step_count | | | 00C9 C3 254 | | clr c | | | 00CA 9450 255 | | subb a,#80 | | | 00CC 400C 256 | | jc di_3 | | | 00CE A202 257 | | mov c,r_wall | ;store R wall into decide storage | | 00D0 9211 258 | | mov r_decide,c | ; for use later in CASE | | 00D2 A203 259 | | mov c,l_wall | are in a second and a second and a second | | 00D4 9212 260 | | mov l_decide,c | ; when CASE statment is built below | | 00D6 C21D 261 | | clr skip_decide | | | 00D8 2197 262 | | ajmp di_9 | ;get out since did above stuff | | 263 | | | | | 264 | | ;3)detect no wall to w | wall (lo to hi) and check for front wall | | 265 | | | than 120 to allow for spaces in posts | | 00DA E508 266 | | mov a, step_count | | | 00DC C3 267 | | clr c | | | 00DD 9478 268 | | subb a,#120 | | | 00DF 4020 269 | | jc di_3_1 | | | 00E1 A215 270 | | mov c,prev_r | ; the prev should be low | | 332 M23 | | | | | | | | | | MCS-51 MACRO | ASSEMB | LER | 751MAIN | | | 04/16/92 PAGE 6 | |--------------------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | LOC OBJ | | TIME | COLIDOR | | | | | 00E3 A002 | | LINE | SOURCE | | , | | | 00E5 400A | | 271 | | orl | c,/r_wall | ; check for r wall transition | | OUES 400A | | 272 | | jc | di_3_0 | ;IF no lo to hi then di_3_0 | | 0007 750000 | _ | 273 | | | | lo to hi, set step counter | | 00E7 750800<br>00EA C213 | F | 274 | | mov | step_count, #w21 | nw_cnt | | 00EA C213 | | 275 | | clr | f_decide | | | 00EC 730B00 | | 276 | | mov | count_fw,#0 | clr count for use in decel S.R. | | 00EF D218<br>00F1 A216 | | 277 | 11 0 0 | setb | det_L2H | | | 00F1 A216<br>00F3 A003 | | 278 | di_3_0: | mov | c,prev_l | ;the prev should be low | | 00F5 400A | | 279 | | orl | c,/l_wall | ; check for 1 wall transition | | AUOF CIOO | | 280 | | jc | di_3_1 | ;IF no lo to hi then di_3_1 | | 00F7 750800 | F | 281 | | | lo to hi, set st | | | 00F7 730800<br>00FA C213 | r | 282 | | mov | step_count, #w2r | nw_cnt | | 00FC 750B00 | | 283 | | clr | f_decide | | | | | 284 | | mov | count_fw,#0 | | | 00FF D218 | | 285 | | setb | det_L2H | | | | | 286 | di_3_1: | | ;condit | cion that will get you to di_3_9 | | 0101 3004 | | 287 | of the same | | ;det_L2 | 2H & count > 162 | | 0101 A204 | | 288 | | mov | c,f_wall | ; trigger from extrn lite during | | 0103 9213 | | 289 | | mov | f_decide,c | ; other points in square | | 0105 400E | | 290 | | jc | di_3_9 | ;get out if meet condition ELSE contnu | | 0107 3018CE | | 291 | | nb jnb | $det_L2H, di_2_0$ | ;this section checks second cond | | | | 292 | | | | | | 010A E50B | | 293 | | mov | a,count_fw | | | 010C B40002 | F | 294 | | cjne | a,#chk4fr,di_3_ | _2 | | 010F 2115 | | 295 | | ajmp | di_3_9 | | | 0111 050B | | 296 | DI_3_2: | inc | count_fw | | | 0113 2197 | | 297 | | ajmp | di_9 | ;get out | | | | 298 | | | | | | | | 299 | di_3_9: ;at | this point | we have detected | lit's time to stop, store in RAM, and | | | | 300 | ; ex | ecute plan | Therefore set | bit to skip all of this | | 0115 201DC0 | | 301 | | jb | skip_decide,di_ | 2_0 | | 0118 D21D | | 302 | | setb | skip_decide | | | | | 303 | | | | | | 011A C218 | | 304 | | clr | det_L2H | | | 011C 750800 | | 305 | | mov | step_count,#0 | | | 011F 202054 | | 306 | | jb | done, dif_0 | ; IF done THEN dif_0 ELSE fall thru | | | | 307 | | | | | | | | 308 | di_4: | ;4) at | this point F L R | are loaded, set up CASE table | | | | 309 | ; · I | | =11 stop-mouse= | | | 0122 7400 | | 310 | | mov | a,#0 | | | 0124 A221 | | 311 | | mov | c,l_r_bit | ; if no back up then we have this | | 0126 33 | | 312 | | rlc | a | | | 0127 A212 | | 313 | | mov | c,l_decide | | | 0129 33 | | 314 | | rlc | a | ; L/R_bit 1=L | | 012A A211 | | 315 | | mov | c,r_decide | ; 0=R | | 012C 33 | | 316 | | rlc | a · · · · · · · · · · · · · · · · · · · | | | 012D A213 | | 317 | | mov | c,f_decide | $ \mathbf{r}^{\prime\prime} ^{\frac{1}{2}}$ for each $ \mathbf{r}^{\prime\prime} ^{\frac{1}{2}}$ and $ \mathbf{r}^{\prime\prime} ^{\frac{1}{2}}$ | | 012F 33 | | 318 | | rlc | a | ; 0 0 0 0 L/R L R F | | 0130 9001A1 | | 319 | | mov | dptr,#d_table | ;point to decision table | | 0133 93 | | 320 | | movc | a,@a+dptr | ;get decision | | 0134 FA | | 321 | | mov | r2,a | ;save it for later | | | | 322 | | | ************************************** | | | 0135 201A14 | | 323 | | jb | back_up,di_4_0 | ; IF backing up GOTO di | | | | 324 | ;5) | | | . A part is taken care of here | | 0138 A2E7 | | 325 | | mov | c,acc.7 | ;setting make_180 flag | | | | | | | | | ## **AN443** | MCS-51 MACRO ASSEMBLER | 751MAIN | | | 04/16/92 PAGE 7 | |------------------------------|---------|-----------|------------------|------------------------------------| | LOC OBJ LINE | SOURCE | | | | | 013A 9214 326 | | mov | make_180,c | | | 013C 9210 327 | | mov | get_out,c | | | 013E 921A 328 | | mov | back_up,c | | | 0140 4055 329 | | jc | di_9 | ;if make_180 then return | | 330 | | - | | direction to turn | | 0142 5403 331 | | anl | a,#00000011b | ;mask out junk to get D | | 0144 F5F0 332 | | mov | b,a | | | 0146 31E3 333 | | acall | store_val | ;store the decision and then store | | 0148 31C1 334 | | acall | inc_map_ptr | ; a halt afterwards and decr | | 335 | | | | | | 014A 802E 336 | | sjmp | dx_58 | ;go execute it below | | 337 | | -3 | | | | 014C 31D2 338 | di_4_0: | acall | dec_map_ptr | | | 014E 5117 339 | u1_1_0. | acall | get_val | ;get top of stack, put in B | | 0150 EA 340 | | mov | a,r2 | ygoo cop or beach, pao in i | | 0151 5403 341 | | anl | a,#00000011b | ;keep D (dir to turn) | | 0153 C5F0 342 | | xch | a, #00000011D | ;stack top in A, D in B | | 0155 23 343 | | rl | | ;stack top now looks like this | | | | | a | | | 0156 23 344<br>0157 45F0 345 | | rl | a | | | | | orl | a,b | ;looks like 0000 prev D | | 0159 D2E4 346 | | setb | acc.4 | ;looks like 000 B/U prev D | | 347 | | | | 4 | | 015B 93 348 | | MOVC | a,@a+dptr | get decision | | 015C FA 349 | | mov | r2,a | ;save it just in case | | 015D C214 350 | | clr | make_180 | | | 015F A2E6 351 | | mov | c,acc.6 | setting or clearing back-up | | 0161 921A 352 | | mov | back_up,c | | | 0163 201A14 353 | | jb | back_up,dx_58 | ;if still backing, dont store | | 0166 C4 354 | | swap | a | | | 0167 5403 355 | | anl | a,#00000011b | ; C now in B | | 0169 F5F0 356 | | mov | b,a | | | 016B 31E3 357 | | acall | store_val | ; and now stored in RAM | | 016D 31C1 358 | | acall | inc_map_ptr | | | 016F EA 359 | | mov | a,r2 | ;get decision and mask to get | | 0170 5403 360 | | anl | a,#0000011b | ; D dir to turn | | 0172 F5F0 361 | | mov | b,a | | | 0174 8004 362 | | sjmp | dx_58 | ;go execute it below | | 363 | | | | | | 364 | ;6) sk | ip all of | the junk above | and do this if running finals | | 365 | dif_0: | ;do thi | s if running fin | al solution | | 0176 5117 366 | | acall | get_val | get the turn decision | | 0178 31C1 367 | | acall | inc_map_ptr | ;incr map pointer | | 368 | | | | | | 369 | | | | | | 370 | ;7) in | terpret A | to set the turn | flags accordingly | | 371 | dx_58: | | | ;r_turn, l_turn flags | | 017A E5F0 372 | | mov | a,b | ;cjne's only work on acc not b | | 017C B40108 373 | | cjne | a,#01,dx_52 | ;look for | | 017F D208 374 | | setb | r_turn | | | 0181 C209 375 | | clr | 1_turn | | | 0183 D210 376 | | setb | get_out | | | 0185 8010 377 | | sjmp | di_9 | | | 0187 B40208 378 | | cjne | a,#02,dx_53 | | | 018A C208 379 | | clr | r_turn | | | 018C D209 380 | | setb | l_turn | | | | | | | | AN443 | MCS-51 MA | CRO ASSEMBLER | 751MAIN | | | 04/16/92 P | AGE 181 81 81 | |-----------|---------------|------------------------------|-------------|---------------------|-----------------------------------------|------------------| | LOC OBJ | LINE | SOURCE | | | | | | 018E D210 | 381 | Booker | setb | get_out | | | | 0190 8005 | 382 | | sjmp | di_9 | | | | 0130 0003 | 383 | dx_53: | | | , straight or stop | | | | 384 | | 00 then st | | , scrargic or scop | | | 0192 B400 | | and the second second second | cjne | a,#0,di_9 | | | | 0195 8153 | 386 | | ajmp | halt | | | | 0230 0233 | 387 | | ajmp | Hare | | | | | 388 | di_9: ;en | d of SR h | ere at di-9 | | | | 0197 A202 | 389 | u1_5. , (cir. | mov | c,r_wall | | | | 0199 9215 | 390 | | mov | prev_r,c | ;store the wall conditi | on for next | | 019B A203 | 391 | | mov | c,l_wall | ; toggle look | on for nexe | | 019D 9216 | 392 | | mov | prev_1,c | , coggie look | | | | 393 | | | p100_1/0 | | | | 019F 412C | 394 | | ajmp | decide_x | | | | 0171 1110 | 395 | | ajmp | decide_x | | | | | | ******* | ****** | ****** | ****** | ***** | | | 397 | d_table: | ·thic | holds all of th | e answers for the decision | table | | | 398 | q_cable. | | | this A B C D | | | | 399 | | | | =B-U flag status | (two bits ea) | | | 400 | | | | in B-U, L=10 R=01 S=11 | aton movac-00 | | | 401 | | | | stack not in B-U (B-U mea | | | | 402 | | | direction to tu | | is back-up mode) | | 01A1 05 | 403 | | db | | 00101b,00001111b,00001010b | | | 01A2 05 | 103 | | ab | 000001010,000 | 00101B,00001111B,00001010B | | | 01A3 OF | | | | | | | | 01A4 0A | | | | | | | | 01A5 05 | 404 | | đb | 000001015 000 | 00101b,00001111b,11001111b | | | 01A6 05 | | | a GD | 000001010,000 | 00101B,00001111B,11001111B | | | 01A7 OF | | | | | | | | 01A8 CF | | | | | | | | 01A9 0A | 405 | | đb | 000010105 000 | 01010b,00001010b,00001010b | | | 01AA 0A | 103 | | ab | 000010101,000 | 01010D,00001010D,00001010D | | | 01AB 0A | | | | | | | | 01AC 0A | | | | | | | | 01AD OF | 406 | | db a | 000011116 000 | 00101b,00001111b,11001111b | | | 01AE 05 | | | | | 001011,00001111111111111111111111111111 | | | 01AF OF | | | | | | | | 01B0 CF | | | | | | | | | 407 | : the | ese lines a | re for the B-II | mode decisions, some non-va | alid | | 01B1 00 | 408 | | db | 00h,00h,00h,00 | | alla | | 01B2 00 | | | - | 0011, 0011, 0011, 0 | | | | 01B3 00 | | | | | | | | 01B4 00 | | | | | | | | 01B5 00 | 409 | | đb | 00h 00110001h | ,01000010b,00100011b | | | 01B6 31 | | | | 0011,001100012 | ,010000100,001000112 | | | 01B7 42 | | | | | | | | 01B8 23 | | | | | | | | 01B9 00 | 410 | | đb | 00h 01000001h | ,00110010b,00010011b | | | 01BA 41 | | | | 3011, 020000011 | ,001100100,000100110 | | | 01BB 32 | | | | | | | | 01BC 13 | | | | | | | | 01BD 00 | 411 | | đb | 00h.00100001h | ,00010010b,01000011b | | | 01BE 21 | | | | | , 555250101, 510000111 | | | 01BF 12 | | | | | | | | 01C0 43 | | | | | | | | | | | | | | | June 1993 AN443 | MCS-51 MACRO ASSI | MBLER 751MAIN | | | 04/16/92 | PAGE 9 | |-------------------|---------------|---------------------|-------------------|-----------------------|-------------------| | LOC OBJ | LINE SOURC | E | | | | | | 412 | | | | | | | 413 | :101 | 0 0 0 L/R | L R F for | normal address | | | 414 | | 0 0 B/U PREV | | back-up address | | | 415 | | | s 2 bits | | | | | ****** | ' | | | | | | representation in | | ke this | | | | | ost sig 2 bits XX | | | | | | | | | is the first decision | n. B is second | | | | | | e next byte of RAM is | | | | | requires R1 as po | | | | | | | 0 R=01 S=11 sto | | 1 represented as two | bits. | | | | ointer = 3Fh and r | | | | | | | ***** | | | | | | | ap_ptr: ;this : | S.R. incs the map | pointer from 0 to 3 | and map org | | | 426 | | | 1fh and 2ch-3fh. R1 h | | | | 427 | | | | | | 01C1 AF10 | 428 | mov | r7,map_offset | ;cjne only works on | local regs | | 01C3 BF0309 | 429 | cjne | r7,#3,imp_0 | ; IF 3 THEN do below | | | 01C6 7510FF | 430 | mov | | h ;start at MSB two b | | | 01C9 B91F02 | 431 | cjne | r1,#1fh,imp_1 | | , | | 01CC 792B | 432 | mov | r1,#2bh | | | | 01CE 09 | 433 imp_1 | | r1 | ; and also move poi | nter high | | 01CF 0510 | 434 imp_0 | | map_offset | | | | 01D1 22 | 435 | ret | | | | | | 436 | | | | | | | | ***** | * | | | | | • | ap_ptr: ;this | S.R. decr the map | pointer and returns | what's on the | | | 439 | | of the stack in B | | | | 01D2 AF10 | 440 | mov | | ;cjne only works on | local regs | | 01D4 BF0009 | 441 | cjne | r7,#0,dmp_0 | ; IF 0 THEN do below | | | 01D7 751004 | 442 | mov | map_offset,#4 | ;point XX XX XX 00 | | | 01DA B92C02 | 443 | cjne | r1,#2ch,dmp_1 | 333 | | | 01DD A920 | 444 | mov | r1,20h | | | | 01DF 19 | 445 dmp_1 | : dec | r1 | ;map pointer R1 | | | 01E0 1510 | 446 dmp_0 | | map_offset | | | | 01E2 22 | 447 | ret | | | | | | 448 | | | | | | | | ****** | **** | | | | | 450 store | _val: ;requi | res the decision | to be in B as 000000X | XX and pointed to | | 01E3 C7 | 451 | xch | a,@R1 | ;get byte for below | | | 01E4 AEF0 | 452 | mov | r6,b | ;decision is in B | | | 01E6 AF10 | 453 | mov | r7,map_offset | get it | | | 01E8 BF0002 | 454 | cjne | | ;are we at 0 yet? | | | 01EB 8004 | 455 | sjmp | sv_b | ; I guess we are | | | 01ED 03 | 456 sv_a: | rr | a | ;roll bits to shift | 1001xx1001001 | | 01EE 03 | 457 | rr | a | ;to get | xx 00 00 00 | | 01EF DFFC | 458 | djnz | r7,sv_a | ;keep shifting til | | | 01F1 C2E0 | 459 sv_b: | | acc.0 | ;clear it out to loa | | | 01F3 C2E1 | 460 | clr | acc.1 | | | | 01F5 BE0104 | 461 | cjne | r6,#01,sv_0 | ;load R if 01 | | | 01F8 D2E0 | 462 | setb | acc.0 | ;looks like XX XX X | xx 01 | | 01FA 800E | 463 | sjmp | sv_2 | | | | 01FC BE0204 | 464 sv_0: | | r6,#02,sv_1 · | ;load L if 02 | | | 01FF D2E1 | 465 | setb | acc.1 | ;looks like XX XX X | XX 10 | | 0201 8007 | 466 | sjmp | sv_2 | | | | • | | - 3-12- | - | | | AN443 | MCS- | 51 MACRO | ASSEMBI | LER | 751MAIN | | | 04/16/92 | PAGE 10 | |------|----------|---------|------|---------------|-----------|-----------------------------------------|----------------------|--------------------| | LOC | OBJ | | LINE | SOURCE | | | | | | 0203 | BE0304 | | 467 | sv_1: | cjne | r6,#03,sv_2 | | | | | D2E0 | | 468 | | setb | acc.0 | ;load Straight AKA S | 3 | | | D2E1 | | 469 | | setb | acc.1 | ;looks like XX XX | | | | AF10 | | 470 | sv_2: | mov | r7,map_offset | ;roll until bits in | ' ' | | | BF0002 | | 471 | SV_2: | | · | • | Original position | | | 8004 | | | | cjne | r7,#0,sv_c | ;are we at 0 yet? | | | | | | 472 | | sjmp | sv_d | ; I guess we are | 1.01.001.001.001 | | 0211 | | | 473 | sv_c: | rl | а | ;roll bits to shift | | | 0212 | | | 474 | | rl | * a * * * * * * * * * * * * * * * * * * | ;to get | xx 00 00 00 | | | DFFC | | 475 | | djnz | r7,sv_c | ;keep shifting til | 00 xx 00 | | 0215 | | | 476 | sv_d: | xch | a,@R1 | ;put it all back | | | 0216 | 22 | | 477 | | ret | | | | | | | | 478 | | | | | | | | | | 479 | ; ******** | ****** | * | | | | | | | 480 | get_val: | ;this | S.R. returns turn | n value in B | | | 0217 | F509 | | 481 | | mov | temp_reg1,a | ;save acc same as pu | ish acc | | 0219 | E7 | | 482 | | mov | a,@r1 | | | | 021A | AF10 | | 483 | | mov | r7,map_offset | ;get it | | | 021C | BF0002 | | 484 | | cjne | r7,#0,gv_0 | ;are we at 0 yet? | | | | 8004 | | 485 | | sjmp | gv_1 | ; I guess we are | | | 0221 | | | 486 | gv_0: | rr | a | ;roll bits to shift | loolooloolxxl | | 0222 | | | 487 | 9.0. | rr | a | ; to get | 00 00 00 XX | | | DFFC | | 488 | | | | ; keep shifting til | | | | 5403 | | 489 | 1 | djnz | r7,gv_0 | | xx 00 00 00 | | | | | | gv_1: | anl | a,#00000011b | ;now have 00 00 00 | XX | | | F5F0 | | 490 | | mov | b,a | stuff it back | | | | E509 | | 491 | | mov | a,temp_reg1 | | | | 022B | 22 | | 492 | | ret | | | | | | | | 493 | | | | | | | | | | 494 | | | | | | | | | | 495 | ;****** | | | | | | | | | 496 | | | | | | | 022C | 101002 | | 497 | decide_x: | jbc | get_out,decel | ;get out, time to st | op | | 022F | 015C | | 498 | | ajmp . | acc_0 | do this again; | | | | | | 499 | | | | | | | | | | 500 | | | | | | | | | | 501 | ; ******** | ***** | ****** | ****** | ***** | | | | | 502 | ; This sectio | n deceler | ates the motors. | The table value is I | lowered * | | | | | 503 | | | close to a wall. | | * | | | | | 504 | ;******** | ***** | ****** | ****** | ***** | | | | | 505 | | | | | | | | | | 506 | decel: | | | | | | 0231 | AE0B | | 507 | | mov | r6,count_fw | ;get no. steps past | nost from count-fw | | | 7400 | F | 508 | | mov | a,#decel_steps | , get no. steps past | post from count-1w | | 0235 | | - | 509 | | clr | c c | | | | 0236 | | | 510 | | subb | | | | | 0237 | | | 511 | | | a,r6 | | | | 0237 | r E | | | | mov | r6,a | ;R6 now has decel_st | ceps - count_fw | | 0220 | 7000 | | 512 | | 22 | | | | | | 7B00 | F | 513 | | mov | r3,#decel_decr | ;decel decr is now i | | | | E50F | | 514 | | mov | a,r_ptr | ;check to see how fa | ar into accel tab | | 023C | | | 515 | | clr | C | | | | | 9400 | F | 516 | | subb | a,#acc_steps | ;C set if r_ptr < to | p_speed | | 023F | 5002 | | 517 | | jnc | dec_0a | | | | 0241 | 7B01 | | 518 | | MOA | r3,#1 | ;this is the decel_c | lecr value | | | | | 519 | | | | | | | 0243 | EE | | 520 | dec_0a: | mov | a,r6 | | | | 0244 | 8BF0 | | 521 | | mov | b,r3 | | | | | | | | | | | | | | | | | | | | | | | AN443 | MCS-51 MACRO ASSEMBLER | 751MAIN | | | 04/16/92 PAGE 11 | |------------------------|----------------|---------|-------------------|-----------------------------------------| | LOC OBJ LINE | SOURCE | | | | | 0246 A4 522 | | mul | ab | | | 0247 04 523 | | inc | a | | | 0248 F50F 524 | | mov | r_ptr,a | | | 024A F50E 525 | | mov | 1_ptr,a | | | 526 | | | | | | 024C 300BFD 527 | dec_0: | jnb | time_int,\$ | ;stay here until int happens | | 024F C20B 528 | | clr | time_int | | | 0251 71B7 529 | | acall | snapshot | ;take a look at the walls | | 530 | ;right routine | | | | | 0253 300C08 531 | , | jnb | r_int,dec_1 | ; skip if right hasn't been stepped yet | | 0256 C20C 532 | | clr | r_int | | | 0258 E50F 533 | | mov | a,r_ptr | ;get right pointer | | 025A C3 534 | | clr | C | , good a again goalliool | | 025B 9B 535 | | subb | a,r3 | ;slow down by getting lesser value | | 025C F50F 536 | | mov | r_ptr,a | ;ptr just got decremented | | 537 | | IIIO V | 1_pc1,a | ,per just got decremented | | 538 | ;left routine | | | | | 025E 300DEB 539 | dec_1: | jnb | l_int,dec_0 | ;if need to do left then goto dec-1 | | 0261 C20D 540 | 400_1. | clr | l_int | 711 need to do left their goto det 1 | | 0263 E50E 541 | | mov | a,l_ptr | ;get left pointer | | 0265 C3 542 | | clr | c c | ,get left pointer | | 0266 9B 543 | | subb | a,r3 | ;slow down by getting lesser value | | 0267 F50E 544 | | mov | 1 ptr.a | ;ptr just got decremented | | 0269 DEE1 545 | dec_2: | djnz | r6,dec_0 | ;decr number of steps to decel | | 026B C28C 546 | dec_z. | clr | tr0 | ;stop the timer int | | 026D 7F00 F 547 | | mov | r7,#pause_val | ; pause value | | 026F 9145 548 | | acall | pause_var | ;stay stationary for a while | | 549 | | acaii | pause | , stay stationary for a while | | 550 | | | | | | 551 | | ***** | ****** | ******* | | 552 | | makes t | he mouse turn 90 | or 180 degrees using the * | | 553 | | | | * | | 554 | | | | ******** | | 555 | | | | | | 556 | | :routi | ne to pivot the m | ouse 90 or 180 degrees | | 0271 E58B 557 | · <del>-</del> | mov | a,rtl | | | 0273 C3 558 | | clr | c · | | | 0274 9400 F 559 | | subb | a, #pivot_speed | :slower speed | | 0276 30140D 560 | | jnb | | ;do 180 else turn | | 0279 101706 561 | | jbc | cw180,piv_0 | ;180 cw | | 027C D217 562 | | setb | cw180 | ;next time 180 ccw | | 027E C293 563 | | clr | l_dir | ; make L go backwards | | 0280 4190 564 | | ajmp | piv_1 | There is go backwards | | 0282 C291 565 | | clr | r_dir | ; make R go bw | | 0284 4190 566 | | ajmp | piv_1 | That is go bu | | 567 | | u jp | 9-1 | | | 0286 A208 568 | | mov | c,r_turn | ; this section sets the motor dir | | 0288 B3 569 | | cpl | C | ; bits according to which | | 0289 9291 570 | | mov | r_dir,c | ; dir it has to turn. | | 028B A209 571 | | mov | c,l_turn | , dir it has to tarii. | | 028D B3 572 | | cpl | c, i_cdiii | | | 028E 9293 573 | | mov | l_dir,c | | | 574 | | 1110 V | arr, c | | | 575 | | IS NEW. | Mod adds or seek | racts steps depending on sensor info | | 0290 201404 576 | | jb | | | | 570 | | بدر | axe_100,p1v_2y | ;if mouse is skewed, it turns more | | MCS- | 51 MACRO | ASSEMBL | ER | 751MAIN | | | | | 04/16/92 PAGE | 12 | |------|----------|---------|------|-----------------------------------------|---------|----------|-------------------|--------------|--------------------|-----------| | | | | | , , , , , , , , , , , , , , , , , , , , | | | | | 04/10/92 FAGE | 12 | | LOC | | | LINE | SOURCE | | | | | | | | | 7F00 | F | 577 | | | mov | r7,#half_90 | ; or less | degrees | | | | 8002 | | 578 | | | sjmp | piv_2x | | | | | 0297 | 7F00 | F | 579 | piv_2y: | | mov | r7,#half_180 | ; | | | | | | | 580 | piv_2x: | this s | ection d | etermines add or | subt count | depending on dir | to pivot | | | | | 581 | | ;(r_dir | & too_1 | ) (1_dir & too | _r) = - ste | ps | | | | | | 582 | | ;(r_dir | & too_r | ) (l_dir & too | _1) = + ste | ps · | | | | A291 | | 583 | | | mov | c,r_dir | ;check for | first condition | | | | 8201 | | 584 | | | anl | c,too_1 | | | | | | 9222 | | 585 | | | mov | temp_bit1,c | | | | | 029F | A293 | | 586 | | | mov | c,l_dir | | | | | | 8200 | | 587 | | | anl | c,too_r | | | | | 02A3 | 7222 | | 588 | | | orl | c,temp_bit1 | | | | | 02A5 | 5003 | | 589 | | | jnc | piv_2z | | | | | 02A7 | | | 590 | | | dec | r7 | ;decr step | count to do pivot | | | 02A8 | 800F | | 591 | | | sjmp | piv_2v | | | | | 02AA | A291 | | 592 | piv_2z: | | mov | c,r_dir | ;check for | second condition | | | 02AC | 8200 | | 593 | | | anl | c,too_r | | | | | 02AE | 9222 | | 594 | | | mov | temp_bit1,c | | | | | 02B0 | A293 | | 595 | | | mov | c,l_dir | | | | | 02B2 | 8201 / | | 596 | | | anl | c,too_1 | | | | | 02B4 | 7222 | | 597 | | | orl | c,temp_bit1 | | | | | 02B6 | 5001 | | 598 | | | jnc | piv_2v | | | | | 02B8 | 0F | | 599 | | | inc | r7 , | ;incr step | count to do pivot | | | | | | 600 | | | | | | i di Garage | | | 02B9 | 750F00 | | 601 | piv_2v: | | mov | r_ptr,#0 | ;point at i | first accel value | | | 02BC | 750E00 | | 602 | | | mov | 1_ptr,#0 | | | | | 02BF | 750DFE | | 603 | | | mov | r_timr,#0feh | ; even up th | ne timers to step | | | 02C2 | 750CFE | | 604 | | | mov | l_timr,#0feh | ; evenly | | | | 02C5 | D28C | | 605 | | | setb | tr0 | ;enable tim | ner | | | | | | 606 | | | | | | | | | 02C7 | 300CFD | | 607 | piv_2: | | jnb | r_int,\$ | ;stay here | until done | | | 02CA | C20C | | 608 | | | clr | r_int | ;ack r inte | errupt | | | 02CC | 050F | | 609 | | | inc | r_ptr | ;incr step | count | | | 02CE | 050E | | 610 | | | inc | l_ptr | ;incr step | count | | | 02D0 | E50F | | 611 | | | mov | a,r_ptr | ;see if at | half way mark | | | 02D2 | 201405 | | 612 | | | jb | make_180,piv_2a | | | | | 02D5 | B507EF | | 613 | | | cjne | a,07,piv_2 | ; IF half wa | y fall thru to pi | v_3 | | 02D8 | 8003 | | 614 | | | sjmp | piv_3 | | | | | 02DA | B507EA | | 615 | piv_2a: | | cjne | a,07,piv_2 | ;if half wa | y, fall thru | | | | | | 616 | | | | | | | | | | B40002 | F | 617 | piv_3: | | cjne | a, #look90, piv_4 | | | | | 02E0 | D21B | | 618 | piv_3a: | | setb | look | ;if so, set | look bit | | | 02E2 | 300CFD | | 619 | piv_4: | | jnb | r_int,\$ | ;stay here | until int done | | | 02E5 | C20C | | 620 | | | clr | r_int | ;ack int | | | | 02E7 | 150F | | 621 | | | dec | r_ptr | ;make it sl | ow down | | | 02E9 | 150E | | 622 | | | dec | 1_ptr | | | | | 02EB | 301B11 | | 623 | | | jnb | look,piv_5 | ;if look is | set, do snapshot | | | | | | 624 | | | | | | | | | 02EE | 71B7 | | 625 | | | acall | snapshot | ;if aligned | l & wall exist tru | th table: | | 02F0 | 20051C | | 626 | | | jb | aligned, piv_end | | | | | 02F3 | A201 | | 627 | | | mov | c, too_1 | | | | | 02F5 | B093 | | 628 | | | anl | c,/l_dir | | | | | 02F7 | 4016 | | 629 | | | jc | piv_end | | | | | 02F9 | A200 | | 630 | | | mov | c,too_r | | | | | 02FB | B091 | | 631 | | | anl | c,/r_dir | | | | | | | | | | | | | | | | | MCS-51 MACRO ASSEMBL | ER 75 | 1MAIN | | | 04/16/92 PAGE 13 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LOC OBJ | LINE | SOURCE | | | | | 02FD 4010 | 632 | | jc | piv_end | | | | 633 | | | | | | 02FF E50F | 634 | piv_5: | mov | a,r_ptr | The state of s | | 0301 70DA | 635 | | jnz | piv_3 | ; IF end of count fall thru | | | 636 | | | | | | 0303 A202 | 637 | | mov | c,r_wall | | | 0305 7203 | 638 | | orl | c,l_wall | | | 0307 5006 | 639 | | jnc | piv_end | ; IF no walls get out | | | 640 | | | | | | 0309 050F | 641 | | inc | r_ptr | ; keep steppin while you see | | 030B 050E | 642 | | inc | 1_ptr | ; a wall | | 030D 41E2 | 643 | | ajmp | piv_4 | | | | 644 | | | | | | | 645 | piv_end: | | | | | 030F C28C | 646 | | clr | tr0 | ;off timer int | | 0311 850A8B | 647 | | mov | rt1,1s373 | ;full speed again | | 0314 C21B | 648 | | clr | look | <b>;</b> | | 0316 C20C | 649 | | clr | r_int | | | 0318 C20D | 650 | | clr | 1_int | | | 031A 43900A | 651 | | orl | p1,#00001010b | ;set r dir l dir | | 031D 7F00 F | 652 | | mov | r7, #pause_val | ;pause for a bit | | 031F 9145 | 653 | | acall | pause | | | | 654 | | 44.0 | 4380 | | | 0321 0141 | 655 | | ajmp | accel | ;goto accel | | The state of s | 656 | | | | | | | 657 | | | | | | | 658 | ,******** | ****** | ****** | ****** | | | | | | | | | | 659 | ; This is the ' | | | | | | 659<br>660 | | Timer 0 | interrupt subrout | ine. * | | | 660 | ; It will step | Timer 0<br>a motor | interrupt subrout<br>if the "prescale | ine. * " for the corresponding * | | | 660<br>661 | ; It will step<br>; motor overflo | Timer 0<br>a motor<br>ows (or | interrupt subrout<br>if the "prescale<br>decrements to zer | ine. * " for the corresponding * | | | 660<br>661<br>662 | ; It will step<br>; motor overflo | Timer 0<br>a motor<br>ows (or | interrupt subrout<br>if the "prescale<br>decrements to zer | ine. * " for the corresponding * o). * | | | 660<br>661<br>662<br>663 | ; It will step<br>; motor overflo<br>;******* | Timer 0 : a motor ows (or | interrupt subrout if the "prescale decrements to zer ************************************ | ine. | | 0323 C28C | 660<br>661<br>662<br>663<br>664 | ; It will step<br>; motor overflo | a motor ows (or ******* | interrupt subrout<br>if the "prescale<br>decrements to zer | ine. | | 0323 C28C | 660<br>661<br>662<br>663<br>664<br>665 | ; It will step<br>; motor overflo<br>;******* | a motor ows (or ****** ;used clr | interrupt subrout if the "prescale decrements to zer ***************** to step the motor tr0 | ine. | | 0325 C0D0 | 660<br>661<br>662<br>663<br>664<br>665 | ; It will step<br>; motor overflo<br>;******* | rimer 0 a motor ows (or ******* ;used clr push | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw | ine. | | 0325 C0D0<br>0327 C0E0 | 660<br>661<br>662<br>663<br>664<br>665<br>666 | ; It will step<br>; motor overflo<br>;******* | rimer 0 a motor ows (or ****** ;used clr push push | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw acc | ine. | | 0325 C0D0<br>0327 C0E0<br>0329 C082 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667 | ; It will step<br>; motor overflo<br>;******* | a motor ows (or ;used clr push push | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw acc dpl | ine. | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669 | ; It will step<br>; motor overflo<br>;******* | a motor ows (or '****** ;used clr push push push | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw acc dpl dph | ine. | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083<br>032D 900000 F | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669 | ; It will step<br>; motor overflo<br>;******* | rimer 0 a motor ows (or '****** ;used clr push push push push mov | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab | ine. | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083<br>032D 900000 F | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670 | ; It will step<br>; motor overflo<br>;******* | rimer 0 : a motor ows (or o *********** ;used clr push push push push mov djnz | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 | ine. * " for the corresponding * o). * *********************************** | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083<br>032D 900000 F<br>0330 D50D16 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672 | ; It will step<br>; motor overflo<br>;******** | a motor a motor ws (or """ ;used clr push push push push push mov djnz clr | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step | ine. | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083<br>032D 900000 F<br>0330 D50D16<br>0333 C292<br>0335 E50F | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673 | ; It will step<br>; motor overflo<br>;******** | a motor a motor ws (or """ ;used clr push push push push mov djnz clr mov | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr | ine. * " for the corresponding * o). * ********** s ;quit counting ;step the R motor ;load timer value from pointer | | 0325 CODO 0327 COEO 0329 CO82 032B CO83 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674 | ; It will step<br>; motor overflo<br>;******** | rimer 0 : a motor ows (or extension of the column of the column of the column of the column own of the column own own own own own own own own own ow | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr | ine. * " for the corresponding * o). * ********* s ;quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083<br>032D 900000 F<br>0330 D50D16<br>0333 C292<br>0335 E50F<br>0337 93 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674 | ; It will step<br>; motor overflo<br>;******** | rimer 0: a motor ows (or ******* ;used clr push push push push mov djnz clr mov movc mov | interrupt subrout if the "prescale decrements to zer ******** to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a | ine. * " for the corresponding * o). * ********** s ;quit counting ;step the R motor ;load timer value from pointer | | 0325 C0D0<br>0327 C0E0<br>0329 C082<br>032B C083<br>032D 900000 F<br>0330 D50D16<br>0333 C292<br>0335 E50F<br>0337 93<br>0338 F50D | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676 | ; It will step<br>; motor overflo<br>;******** | a motor a motor ws (or """ ;used clr push push push push mov djnz clr mov movc mov | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr, #acc_tab r_timr,tim_00 r_step a,r_ptr a,0a+dptr r_timr,a a,step_count | ine. * " for the corresponding * o). * ********* s ; quit counting ; step the R motor ; load timer value from pointer ; get higher byte accel value | | 0325 C0D0 0327 C0E0 0329 C082 032B C083 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676 | ; It will step<br>; motor overflo<br>;******** | a motor a motor ws (or """ ;used clr push push push mov djnz clr mov mov comov cjne | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x | ine. * " for the corresponding * o). * ********* s ; quit counting ; step the R motor ; load timer value from pointer ; get higher byte accel value | | 0325 C0D0 0327 C0E0 0329 C082 032B C083 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>673<br>674<br>675<br>676<br>677<br>678 | ; It will step<br>; motor overflo<br>;*************<br>tim_0: | a motor a motor ws (or """ ;used clr push push push mov djnz clr mov mov cor mov mov cjne sjmp | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y | ine. " for the corresponding * o). ********* s; quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table | | 0325 C0D0 0327 C0E0 0329 C082 032B C083 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676<br>677<br>678<br>679 | ; It will step<br>; motor overflo<br>;********<br>tim_0: | a motor a motor ws (or """ ;used clr push push push mov djnz clr mov mov cone sjmp inc | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count | ine. " for the corresponding * o). ********** s; quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff | | 0325 CODO 0327 COEO 0329 CO82 032B CO83 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>670<br>671<br>672<br>673<br>674<br>675<br>676<br>677<br>678<br>679<br>680 | ; It will step<br>; motor overflo<br>;*************<br>tim_0: | a motor a motor ws (or """ ;used clr push push push mov djnz clr mov mov cone sjmp inc setb | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count r_int | ine. " for the corresponding * o). ********** s; quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff ;flag that the R mot was stepped | | 0325 CODO 0327 COEO 0329 CO82 032B CO83 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 0343 D20C 0345 D20B | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676<br>677<br>678<br>679<br>680<br>681 | ; It will step<br>; motor overflo<br>;********<br>tim_0: | a motor a motor ws (or """ ;used clr push push push push mov djnz clr mov mov cjne sjmp inc setb setb | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count r_int time_int | ine. " for the corresponding * o). ********** s; quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff | | 0325 C0D0 0327 C0E0 0329 C082 032B C083 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 0343 D20C 0345 D20B | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>677<br>678<br>679<br>680<br>681<br>682 | ; It will step; motor overflo; ********* tim_0: tim_x: tim_y: | imer 0 a motor ows (or extension of the column of the column of the column of the column of the column own of the column own own own own own or column own own own own own own own own own ow | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count r_int time_int r_step | ine. " for the corresponding * o). *********************************** s; quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff ;flag that the R mot was stepped ;int has occurred flag | | 0325 C0D0 0327 C0E0 0329 C082 032B C083 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 0343 D20C 0345 D20B 0347 D292 0349 D50C0D | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676<br>677<br>678<br>680<br>681<br>682<br>683 | ; It will step; motor overflo; ******** tim_0: | rimer 0 : a motor ows (or external color push push push mov djnz clr mov mov cjne setb setb djnz | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,ctim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count r_int time_int r_step l_timr,tim_ret | ine. " for the corresponding * o). *********************************** s; ;quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff ;flag that the R mot was stepped ;int has occurred flag ;get out if not zero | | 0325 CODO 0327 COEO 0329 CO82 032B CO83 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 0343 D20C 0345 D20B 0347 D292 0349 D50COD 034C C294 | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676<br>677<br>678<br>680<br>681<br>682<br>683<br>684 | ; It will step; motor overflo; ********* tim_0: tim_x: tim_y: | rimer 0 : a motor ows (or extension of the color c | interrupt subrout if the "prescale decrements to zer ********** to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,tim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count r_int time_int r_step l_timr,tim_ret l_step | ine. "for the corresponding * o). ********************************** s; ;quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff ;flag that the R mot was stepped ;int has occurred flag ;get out if not zero ;step the L motor | | 0325 C0D0 0327 C0E0 0329 C082 032B C083 032D 900000 F 0330 D50D16 0333 C292 0335 E50F 0337 93 0338 F50D 033A E508 033C B48202 033F 8002 0341 0508 0343 D20C 0345 D20B 0347 D292 0349 D50C0D | 660<br>661<br>662<br>663<br>664<br>665<br>666<br>667<br>668<br>669<br>670<br>671<br>672<br>673<br>674<br>675<br>676<br>677<br>678<br>680<br>681<br>682<br>683 | ; It will step; motor overflo; ********* tim_0: tim_x: tim_y: | rimer 0 : a motor ows (or external color push push push mov djnz clr mov mov cjne setb setb djnz | interrupt subrout if the "prescale decrements to zer ********* to step the motor tr0 psw acc dpl dph dptr,#acc_tab r_timr,ctim_00 r_step a,r_ptr a,@a+dptr r_timr,a a,step_count a,#130,tim_x tim_y step_count r_int time_int r_step l_timr,tim_ret | ine. " for the corresponding * o). *********************************** s; ;quit counting ;step the R motor ;load timer value from pointer ;get higher byte accel value ;load the timer value from table ;decide uses this stuff ;flag that the R mot was stepped ;int has occurred flag ;get out if not zero | | LOC OBJ LINE SOURCE 0351 F50C 687 mov 1_timr,a ;load the timer value from tal 0353 D20D 688 setb 1_int ;flag that the L mot was step 0355 D20B 689 setb time_int ;int has occurred flag 0357 D294 690 setb 1_step 691 tim_ret: 0359 D083 692 pop dph 035B D082 693 pop dpl 035D D080 694 pop acc 035F D0B0 695 pop psw 0361 D28C 696 setb tr0 ;start counting 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 0368 699 0700 ;*** 701 ; This is the External interrupt 1 subroutine. * 0702 ;*** 703 int_1: ;used for setting left or right hug 0364 D2010 707 jb done, int_1_2 ;incr speed and get out 0367 10210B 708 jbc l_r_bit, int_1_0 036A D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036B 7F0A 711 mov r7, #10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 D25 716 int_1_2: mov r6, #5 0378 C282 719 int_1_1: jnb done, int_1_3 0370 058B 718 int_1_1: jnb done, int_1_3 0370 058B 718 int_1_1: jnb done, int_1_3 0370 058B 718 int_1_1: jnb done, int_1_3 0370 058B 7702 720 0380 7702 721 call pause | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| | 0351 F50C 687 mov l_timr,a ;load the timer value from tal 0353 D20D 688 setb l_int ;flag that the L mot was step; 0357 D294 690 setb l_step 0357 D294 690 setb l_step 0359 D083 692 pop dph 0359 D080 694 pop acc 0359 D080 695 pop psw 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 0369 699 0360 D28C 696 setb tr0 ;start counting 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 0363 32 697 reti 0364 202010 707 ; This is the External interrupt 1 subroutine. * 0364 202010 707 jb done,int_l_2 ;incr speed and get out 0367 10210B 708 jbc l_r_bit ;hug left 0368 D221 709 setb l_r_bit ;hug left 0368 D221 709 setb l_r_bit ;hug left 0368 TF0A 711 mov r7,#10 ;value for 2 seconds 0374 32 714 reti 0375 C221 715 int_l_0: clr l_r_bit ;hug right 0377 7E05 716 int_l_2: mov r6,#5 0378 C282 719 int_l_3: clr l_led 0368 TF02 720 mov r7,#2 0380 39145 721 acall pause | 14 | | 0351 F50C 687 | | | 0353 D2DD 688 setb 1_int ;flag that the L mot was step 0355 D2DB 689 setb time_int ;int has occurred flag 0357 D294 690 setb time_int ;int has occurred flag 0359 D083 692 pop dph 0358 D082 693 pop dpl 0350 D080 694 pop acc 0357 D0D0 695 pop psw 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 0363 32 697 reti 0364 202010 707 ; This is the External interrupt 1 subroutine. 0364 202010 707 jb done,int_1_2 ;incr speed and get out 0367 T0210B 708 jbc 1_r_bit, int_1_0 0368 D221 709 setb 1_r_bit int_1_0 0369 Setb 1_r_bit int_1 0360 C282 710 clr 1_led 0360 709 145 712 acall pause 0370 P37 P605 716 int_1_0: clr 1_r_bit ;hug right 0377 D250 716 int_1_1: jnb done,int_1_3 0379 303000 717 int_1_1: jnb done,int_1_3 0370 C38B 718 inc ret 0380 7702 720 0380 7702 720 0380 7702 721 0380 7702 721 0380 7702 721 0390 C282 719 int_1_1: jnb done,int_1_3 0370 C38B 718 0370 C38B 718 0370 C38C 719 0380 7702 720 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 720 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0380 7702 721 0390 7202 721 0390 7202 721 0390 7202 721 0390 7202 720 0390 7702 720 0390 7702 721 0300 7200 77,#22 0380 7702 720 0300 7702 720 0300 7702 720 0300 7702 720 0300 7702 720 0300 7702 720 0300 7702 720 0300 7702 7702 03 | nhla | | 0355 D20B 689 setb time_int ;int has occurred flag 0357 D294 690 setb l_step 0359 D083 692 pop dph 0358 D082 693 pop dpl 0359 D080 694 pop acc 0357 DD00 695 pop psw 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 0363 32 697 reti 0364 202010 707 pb done,int_l_3 0366 TFOA 711 mov r7,#10 ;value for 2 seconds 0370 0345 712 acall pause 0370 2037 7805 716 int_l_1: inb done,int_l_3 0370 C58B 718 0370 C502 POP D09 psw 0361 D28C 696 setb tr0 ;start counting 0359 D080 695 pop psw 0361 D28C 696 setb tr0 ;start counting 0362 C282 710 clr l_rbit, int_l_0 0363 Setb l_rbit; int_l_0 0364 D221 709 setb l_rbit; int_l_0 0365 TFOA 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0371 D28C 715 int_l_1: inb done,int_l_3 0372 D28C 715 int_l_1: jnb done,int_l_3 0373 D2002 717 int_l_1: jnb done,int_l_3 0376 C282 719 int_l_1: jnb done,int_l_3 0376 C282 719 int_l_1: jnb done,int_l_3 0376 C282 719 int_l_1: jnb done,int_l_3 0376 C28C 719 int_l_1: jnb done,int_l_3 0376 C28C 719 int_l_1: jnb done,int_l_3 0376 C28C 719 int_l_1: jnb done,int_l_3 0376 C28C 719 int_l_1: jnb done,int_l_3 0376 C28C 719 int_l_1: jnb done,int_l_3 0376 C28C 719 int_l_3: clr l_led 0386 7FO2 720 mov r7,#2 0382 9145 721 acall pause | | | Seth | ppea | | 0359 D083 692 pop dph | | | 0359 D083 692 pop dph 035B D082 693 pop dpl 035D D0E0 694 pop acc 035F D0D0 695 pop psw 0361 D2EC 696 setb tr0 ;start counting 0363 32 697 reti 698 699 700 701 ; This is the External interrupt 1 subroutine. 702 703 704 int_1: ;used for setting left or right hug 705 ; L/R=0 right algo, L/R=1 left algo 706 ;AND also setting speed of run 0364 D221 707 0366 C282 710 clr l_led 0366 T70A 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0370 9282 713 setb l_led 0371 2021 715 int_10: clr l_r_bit ;hug right 0377 7ED5 716 int_12: mov r6,#5 0379 D020 717 int_11: jnb done,int_13 0370 C58B 718 inc rt1 _inc the speed 0380 T702 720 0380 T702 720 0380 T702 720 0380 T702 720 0381 pause 039145 721 acall pause 0370 C584 718 inc rt1 _inc the speed 0380 T702 720 | | | 035B D082 693 pop dpl 035D D080 694 pop acc 035F D0D0 695 pop pop psw 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 698 699 700 ;*********************************** | | | 035D DDEO 694 pop acc 035F DDDO 695 pop psw 0361 D28C 696 setb tr0 ;start counting 0363 32 697 reti 698 699 700 ;*********************************** | | | 035F DDDO 695 | | | 0361 D28C 696 setb tr0 ;start counting 698 699 700 ;*********************************** | | | 0363 32 697 reti 698 699 700 ;*********************************** | | | 698 699 700 701 701 702 703 703 704 705 705 706 706 707 707 708 708 708 709 709 709 709 709 709 709 709 709 709 | | | 699 | | | 700 ;*********************************** | | | 701 ; This is the External interrupt 1 subroutine. 702 ;************************************ | | | 702 703 704 int_1: ;used for setting left or right hug 705 706;AND also setting speed of run 0364 202010 707 0367 10210B 708 036A D221 709 036C C282 710 036E 7FOA 711 711 712 713 714 715 715 716 717 717 718 719 719 719 719 719 719 719 719 719 719 | * | | 703 704 int_1: ;used for setting left or right hug 705; ;L/R=0 right algo, L/R=1 left algo 706; ;AND also setting speed of run 0364 202010 707 jb done,int_1_2;incr speed and get out 0367 10210B 708 jbc l_r_bit, int_1_0 0368 D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036E 7F0A 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 7E05 716 int_1_2: mov r6,#5 0379 302002 717 int_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | * ' ' ' | | 704 int_1: ;used for setting left or right hug 705 ; L/R=0 right algo, L/R=1 left algo 706 ;AND also setting speed of run 0364 202010 707 jb done,int_1_2 ;incr speed and get out 0367 10210B 708 jbc l_r_bit, int_1_0 036A D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036E 7F0A 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0374 32 714 reti 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 TEO5 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 0380 7F02 720 mov r7,#2 0380 9145 721 acall pause | * | | 705 706 706 707 706 707 707 707 708 708 708 708 708 709 709 709 709 709 709 709 709 709 709 | | | 706 ;AND also setting speed of run 0364 202010 707 jb done,int_1_2 ;incr speed and get out 0367 10210B 708 jbc l_r_bit, int_1_0 036A D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036E 7FOA 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 7EO5 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 0380 7FO2 720 mov r7,#2 0382 9145 721 acall pause | | | 0364 202010 707 jb done,int_1_2 ;incr speed and get out 0367 10210B 708 jbc l_r_bit, int_1_0 036A D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036E 7FOA 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 7EO5 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 038C 7FO2 720 mov r7,#2 0382 9145 721 acall pause | | | 0367 10210B 708 jbc l_r_bit, int_1_0 036A D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036E 7FOA 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 7EO5 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 038C 7FO2 720 mov r7,#2 0382 9145 721 acall pause | | | 036A D221 709 setb l_r_bit ;hug left 036C C282 710 clr l_led 036E 7F0A 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0375 C221 715 int_l_0: clr l_r_bit ;hug right 0377 T205 716 int_l_2: mov r6,#5 0379 302002 717 int_l: jnb done,int_l_3 037C 058B 718 inc rtl ;incr the speed 037E C282 719 int_l_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 036C C282 710 | | | 036E 7F0A 711 mov r7,#10 ;value for 2 seconds 0370 9145 712 acall pause 0372 D282 713 setb l_led 0374 32 714 reti 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 7E05 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 037E C282 719 int_1_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0370 9145 712 acall pause 0372 D282 713 setb l_led 0374 32 714 reti 0375 C221 715 int_l_0: clr l_r_bit ;hug right 0377 7E05 716 int_l_2: mov r6,#5 0379 302002 717 int_l_1: jnb done,int_l_3 037C 058B 718 inc rtl ;incr the speed 037E C282 719 int_l_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0372 D282 713 setb l_led 0374 32 714 reti 0375 C221 715 int_l_0: clr l_r_bit ;hug right 0377 7E05 716 int_l_2: mov r6,#5 0379 302002 717 int_l_1: jnb done,int_l_3 037C 058B 718 inc rtl ;incr the speed 037E C282 719 int_l_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0374 32 714 reti 0375 C221 715 int_1_0: clr l_r_bit ;hug right 0377 7E05 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 037E C282 719 int_1_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0375 C221 715 int_1_0: clr 1_r_bit ;hug right 0377 7E05 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rt1 ;incr the speed 037E C282 719 int_1_3: clr 1_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0377 7E05 716 int_1_2: mov r6,#5 0379 302002 717 int_1_1: jnb done,int_1_3 037C 058B 718 inc rt1 ;incr the speed 037E C282 719 int_1_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0379 302002 717 int_1: jnb done,int_1_3 037C 058B 718 inc rtl ;incr the speed 037E C282 719 int_1_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 037C 058B 718 inc rt1 ;incr the speed 037E C282 719 int_1_3: clr l_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 037E C282 719 int_1_3: clr 1_led 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0380 7F02 720 mov r7,#2 0382 9145 721 acall pause | | | 0382 9145 721 acall pause | | | 0204 page | | | 0204 7000 | | | 0384 D282 722 setb 1_led | | | 0386 7F02 723 mov r7,#2 | | | 0388 9145 724 acall pause | | | 038A DEED 725 djnz r6,int_1_1 | | | 038C 32 726 reti | | | 727 | | | 728 | | | 729 ;************************************ | | | 730 ; This is the External interrupt 0 subroutine. | | | 731 ;************************************ | , | | 732 | | | 733 int_0: ;used for starting and stopping the thing | | | 038D C28C 734 clr starting and stopping the thing | | | 0398 200006 | | | , we are here to start | . up | | 0304 0300 | | | 0306 6137 | | | 0300 0000 | | | , we are here cause at finish b | | | done , terr the prog that we are don | ne | | 741 | | | MCS- | 51 MACRO | ASSEMBL | ER | 751MAIN | | | | 04/16/92 | PAGE | 15 | |------|----------|---------|------------|----------------|--------|-----------------|--------------|-----------------------------------------|-----------|----| | LOC | OBJ | | LINE | SOURCE | | | | | | | | 039C | C20A | | 742 | | clr | s_s_int | | | | | | 039E | 90001D | | 743 | | mov | dptr, #main_1 | ;get addre | ss | | | | | A881 | | 744 | | mov | r0,sp | | start all | over | | | | A683 | | 745 | | mov | @r0,dph | | vector to | | | | 03A5 | | | 746 | | dec | r0 | , | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 000111 | | | 03A6 | A682 | | 747 | | mov | @r0,dpl | | | | | | | 75A800 | | 748 | | mov | ie,#00 | | | | | | | 758800 | | 749 | | mov | tcon, #00 | ;clears an | v inte | | | | | | | 750 | | | | , 010010 011 | 3 21100 | | | | 03AE | C297 | | 751 | int_0_ret: | clr | r_led | | | | | | 03B0 | 7F14 | | 752 | | mov | r7,#20 | :value for | 2 seconds | | | | 03B2 | 9145 | | 753 | | acall | pause | , | 2 December | | | | | D297 | | 754 | | setb | r_led | | | | | | 03B6 | 32 | | 755 | | reti | | | | | | | | | | 756 | | | | | | | | | | | | 757 | | | | | | | | | | | | 758 | ******** | ***** | ***** | ****** | ***** | ***** | ** | | | | | 759 | | | the sensors for | | | | * | | | | | 760 | | | ******** | | ***** | ***** | ** | | | | | 761 | | | | | | | | | | | | 762 | snapshot: | :takes | a look at walls | and sets hi | ts accordin | alv | | | | | | 763 | . <del>-</del> | | . ACC, C, r 1 s | | | 1917 | | | 03B7 | 75B0FF | | 764 | ,111, 110 101 | mov | p3,#0ffh | ens, bic add | ressables | | | | | 752000 | | 765 | | mov | ss_bits,#0 | ;clear all | flage | | | | | C281 | | 766 | | clr | r_sens | | ght sensor | hank | | | 03BF | | | 767 | | mul | ab | | 6uS wait st | | | | 03C0 | | | 768 | | mul | ab | , causes a | ous wait st | ace | | | 03C1 | | | 769 | | mu1 | ab | | | | | | 03C2 | | | 770 | | mu1 | ab | | | | | | | E5B0 | | 771 | | mov | | | he11 | | | | | D281 | | 772 | | setb | a,p3 | ;store rig | nt wall | | | | 03C7 | | | 773 | | mov | r_sens<br>r4,a | | | - 1-1-1-1 | | | 03C8 | | | 774 | | rlc | | | ow repr as | | | | | 9204 | | 775 | | | a<br>f wall a | ;store R s | ens 0 for i | _wall | | | | 6002 | | 776 | | mov | f_wall,c | | 1 | | | | | D202 | | 777 | | jz | ss_0 | | l goto ss_( | ) . | | | OJCD | DZUZ | | 778 | | setb | r_wall | ;right wal | 1 present | | | | 03CF | C280 | | 779 | 00.0 | | 1 | | · | | | | 03D1 | | | | ss_0: | clr | l_sens | | ft sensor h | | | | 03D1 | | | 780<br>781 | | mul | ab | ;causes a | 6uS wait st | ate | | | 03D2 | | | | | mul | ab | | | | | | 03D3 | | | 782 | | mu1 | ab | | | | | | | | | 783 | | mul | ab | 212 | | | | | 03D5 | | | 784 | | mov | a,p3 | ;store lef | t wall | | | | 03D7 | | | 785 | | setb | l_sens | | | | | | 03D9 | | | 786 | | mov | r5,a | | ow repr as | _ | | | 03DA | | | 787 | | rlc | a | grab inne; | r sens and | or it | | | | 7204 | | 788 | | orl | c,f_wall | | | | | | | 9204 | | 789 | | mov | f_wall,c | ;store fro | | | | | | 6002 | | 790 | | jz | ss_2 | | l goto ss_2 | : | | | 03E1 | D203 | | 791 | | setb | l_wall | ;left wall | present | | | | | 00047 | | 792 | | | | | | | | | | 20045E | | 793 | ss_2: | jb | f_wall,ss_ret | | nt wall the | | | | 03E6 | | | 794 | | MOA | a,#0 | ;build cas | e statement | : | | | 03E8 | | | 795 | | mov | c,l_r_bit | ; | | | | | 03EA | 33 | | 796 | | rlc | a | ;00000 L/ | R L R | | | | | | | | | | | | | | | AN443 | MCS-51 MACRO ASSEMBLER | 751MAIN | | | 04/16/92 PAGE 16 | |----------------------------------|-----------------------------------------|--------|----------------|----------------------------------------| | LOC OBJ LIN | E SOURCE | | | | | 03EB A203 79 | | mov | c,l_wall | ; algo wall wall | | 03ED 33 79 | 8 | rlc | a | ; bit bit | | 03EE A202 79 | 9 | mov | c,r_wall | | | 03F0 33 80 | 0 | rlc | a | ; done shifting in bits for case stmnt | | 03F1 B40102 80 | 1 | cjne | a,#01,ss_4 | ; chk R | | 03F4 810F 80 | 2 | ajmp | ss_9 | | | 03F6 B40302 80 | 3 ss_4: | cjne | a,#03,ss_5 | ; chk R | | 03F9 810F 80 | | ajmp | ss 9 | | | 03FB B40502 80 | 5 ss_5: | cjne | a,#05,ss_6 | chk R | | 03FE 810F 80 | 6 | ajmp | ss_9 | | | 0400 B40202 80 | 7 ss_6: | cjne | a,#02,ss_7 | ;chk L | | 0403 8115 80 | 8 | ajmp | ss_10 | | | 0405 B40602 80 | 9 ss_7: | cjne | a,#06,ss_8 | ;chk L | | 0408 8115 81 | 0 | ajmp | ss_10 | | | 040A B40737 81 | 1 ss_8: | cjne | a,#07,ss_ret | ; if eq then chk L else do nothing | | 040D 8115 81 | 2 | ajmp | ss_10 | | | 81 | 3 ;******* | | | | | 81 | 4 ss_9: | ;check | the right side | offset | | 040F 8CF0 81 | 5 | mov | b,r4 | ; put wall info into acc | | 0411 C21E 81 | 6 | clr | genp2 | ;0=chk R | | 0413 8004 81 | 7 , , , , , , , , , , , , , , , , , , , | sjmp | ss_93 | | | 0415 8DF0 81 | 8 ss_10: | mov | b,r5 | | | 0417 D21E 81 | 9 | setb | genp2 | ;1=chk L | | 82 | 0 , | | | | | 0419 E5F0 82 | 1 ss_93: | mov | a,b | | | 041B 5400 F 82 | 2 | anl | a,#sens_pat | ;masking for cmp, 3 high 4 low | | 041D B40804 82 | 3 | cjne | a,#08h,ss_90 | ; check for aligned condition | | 0420 D205 82 | 4 | setb | aligned | ;perfectly on wall | | 0422 8144 82 | 5 | ajmp | ss_ret | | | 0424 E5F0 82 | 6 ss_90: | mov | a,b | get wall info again | | 0426 5403 82 | | anl | a,#00000011b | ;check for too close center if a > 0 | | 0428 600B 82 | | jz | ss_91 | ; if no wall on ones then not too_ | | 042A 201E04 82 | | jb | genp2,ss_101 | | | 042D D201 83 | | setb | too_l | | | 042F 8144 83 | | ajmp | ss_ret | | | 0431 D200 83 | <del>-</del> | setb. | too_r | | | 0433 8144 83 | | ajmp | ss_ret | | | 0435 E5F0 83 | | mov | a,b | get wall info again | | 0437 5460 83 | | anl | a,#01100000b | ;check for too close wall if a > 0 | | 0439 6009 83 | | jz | ss_ret | | | 043B 201E04 83 | | jb | genp2,ss_102 | | | 043E D200 83 | | setb | too_r | | | 0440 8144 83 | | ajmp | ss_ret | | | 0442 D201 84 | : | setb | too_1 | | | 0444 22 84 | <del></del> | ret | | | | 84 | | | | | | 84 | | | | *********** | | 0445 0280 84 | | | | s the loop counter | | 0445 C28C 84 | | clr | tr0 | | | 0447 903EFE 84<br>044A D582FD 84 | | mov | dptr,#03efeh | | | | | djnz | dp1,\$ | | | 044D D583FA 84<br>0450 DFF3 84 | | djnz | dph, \$-3 | | | 0450 DFF3 84<br>0452 22 85 | | djnz | r7,pause | | | 85 | | ret | | | | 65 | <del>*</del> | | | | AN443 | MCS-51 MACRO ASSEMBLER 751MAIN 04/16/92 PAGE 17 LOC 0BJ LINE 852 | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------|---------------------------------------|--------------------|------------|------------------------|-------------------| | LOC OBJ LINE SOURCE 852 1 | MCS-51 MACRO ASSEMBLER | 751MAIN | The same series of the control of the | | | 04/16/92 | PAGE 17 | | LINE | | | | | | | | | 852 | | | | | | | | | S5 | ρ | 52 ;**** | ***** | ****** | ****** | ***** | ******* | | 0453 C2A9 | | 53 halt: | ;This | S.R. brings t | he thing | to a halt - most | ly used for debug | | 0455 D290 | 0453 C2A9 8 | 54 | | | | | | | 856 simp \$ 857. 858 EXTRN CODE (acc_tab); from the DOS file 75lace.asm 859 860 end | 0455 D290 8 | E END 10 10 10 10 10 10 10 1 | setb | mot_en | | | | | 858 EXTRN CODE (acc_tab) ; from the DOS file 751acc asm 859 860 end 451 August 15 Aug | 0457 80FE 8 | | sjmp | \$ | | | | | 15.4 Start Francisco Control of | | | ***** | ****** | ****** | ****** | ****** | | end as a second of the control th | | | CODE | (acc_tab) | ;from the | | | | And the control of th | 7. V - A R W 48. | 59 | e i visualita instrumbino | | | | | | See The end standard and see where the second of secon | | 60 | | | | | | | See and the control of o | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | njajednoj ir ato i sas | | | The control of co | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Capital Control of the th | | | | | | | | | The control of co | 하게 되는 것이 많아 하라고 하다고 된 것으로 당하였다.<br>- | | | | | | | | And the control of th | | | | | | | | | Service of the control contro | | | | | | | | | Seminary of the Control Contr | | | | | | | | | AND THE PROPERTY OF PROPER | | | | ad Mily in the son | SEPTION OF | | | | The second of th | | | | | | | | | ල් දැන් කිරීමට පිට කත්තර කත්තර කත්තර දැන්න සහ කත්තර කත්තර කත්තර කත්තර මහ දින්නේ මහ දෙන්නේ සහ සහ කත්තර කත්තර සහ<br>සහ කත්තර සහ 1985 පෙන්නේ දෙන්නේ දින්නේ සහ | | | | | | | | | 는 이 보통하는 1세 대통령 전환 1시 전환 전환 1시 전<br> | | | | | | | | | | e in septiment with sample to | | | | | | | | 1 | | | | | | | | ### Automatic baud rate detection for the 80C51 **AN447** ### Author: Greg Goodhue This note documents a method to automatically establish the correct baud rate for serial communications in many 80C51 family applications. The first character received after a program is started is used to measure the baud rate empirically. This can eliminate the need to have setup switches whose settings are difficult to remember and all of the other headaches associated with applications that use multiple baud rates. One might assume that a reliable method of accomplishing this might be impossible without severely limiting the characters that could be recognized. The problem is in finding a timing interval that can be measured in a large number of possible characters under a wide variety of conditions. Measuring a single bit time would be the obvious way to quickly determine what baud rate is being received. However, many ASCII characters don't have an example of a single bit time in the RS-232 pattern. For most characters, the length of the entire transmission from the start bit to the last "visible" transition will fall within certain ranges as long as some reasonable assumptions can be made about the possible baud rates (i.e. that they are standard baud rates). Moreover, many systems now use 8 data bits and no parity for ASCII transmissions. In this format, normal ASCII characters will never have the MSB set and since UARTs send data LSB first/MSB last. the program would always be able to "see" the beginning of the stop bit. The following baud rate detection routine waits for a start bit (falling edge) on the serial input pin and then starts timer 0. At every subsequent rising edge of the serial data, the timer value is captured and saved. When the timer overflows, the last captured value will indicate the duration of the serial character from the start bit to the last 0 to 1 transition (hopefully the stop bit). The table CmpTable contains the maximum timer measurement that is accepted for each baud rate. These values were picked such that a timed interval of only 4 data bit times (plus the start bit time) will still produce the correct baud rate. There is an assumption in this method that anyone using it needs to be aware of. That is, that this technique depends on only one character being received during the sampling window, which has to be at least as long as a typical character at the slowest baud rate that can be accepted. Essentially this means that the data must normally come from someone typing at a keyboard. On our PCs, we were not able to fool the program by typing two characters in quick succession. The PC function keys did present a problem because they send two characters in a tight sequence, and fooled the program into detecting the wrong baud rate. In the example program, which is designed for a 12 MHz clock, the total sample interval is about 65 milliseconds, or about twice the duration of an RS-232 character sent at 300 baud. If parity is used, a possibility of a baud rate determination error happens when the four MSBs and the parity bit of the character received are all ones. This can happen for the lower case letters "p" through "2", plus curly brackets, vertical bar (I), tilde (~), and "delete", depending on whether the system ses odd or even parity. Note that the usual prompt characters that a user would type to get a system's attention (e.g. space, carriage return, and escape) are NOT subject to this limitation. Because of the way this program works, the first input character that is used to detect the baud rate is lost since the UART cannot be set to the correct baud rate until after the first character has been timed. Also, most "real" programs using this technique would want to repeat the baud rate detection process if framing errors are detected at the UART during normal operation. To calculate CmpTable values for other oscillator frequencies and baud rates, use the following equation: Table entry = $$\frac{\text{Osc}(\text{MHz})}{\text{Baud Rate}} \times \frac{5}{12}$$ Remember that the table entry is a two byte value, so the result of the above must be split into upper and lower bytes (easy if you have a hexadecimal calculator). It may also be possible to get the assembler to do all of the calculations for you. The above equation was derived as follows: Note: '#-of-bits' (the number of "visible" bits) is 9, and bits-to-recognize (the minimum # of bits to recognize) is 5 for 8-N-1 communication. byte time = $$\frac{1}{\text{baud rate}} \times \text{\#-of-bits}$$ machine cycle time = $\frac{\text{Osc frequency}}{12}$ ### Automatic baud rate detection for the 80C51 ``` ******************** Automatic Baud Rate Detection Test ***************** STitle (Automatic Baud Rate Detection Test) $Date(12-16-91) SMOD552 Definitions ************ BIT P3.0 ;Location of serial receive pin. CharH DATA 30h ; Holds high byte of frame timer result. ;Holds low byte of frame timer result. CharL DATA 31h ;Holds final baud rate determination. BaudRate DATA 32h ; Port to display result for debug. Display EQU Reset and Interrupt Vectors 8000h ORG Start: ACALL AutoBaud ;Go try to get a baud rate value. Display, BaudRate ; Display baud rate value for debug. SJMP Start Subroutines ; AutoBaud Rate Detect Routine. Attempts to detect baud rate from first received character, by measuring the length of the character. Some characters may not work properly, primarily those that end with more than 3 (4?) ones in a row. Returns with ACC = baud rate pointer. AutoBaud: MOV ; Initialize timer 0 (UART baud rate timer). TMOD, #01h ; Put timer 0 in 16-bit counter mode. MOV TH0,#0 VOM TL0,#0 VOM TCON, #0 MOV CharH,#0 ;Initialize timer result. MOV CharL, #0 ABO: JB RX, ABO ; Wait for serial start bit. ;Start timer. SETB TRO AB1: JB TFO, AB3 ;Check for timer overflow. ; Check for a rising edge on serial data. JNB RX, AB1 ;Capture timer value at this serial edge. MOV CharH, THO MOV CharL, TL0 ; Check for timer overflow. AB2: JΒ TFO, AB3 ; Check for falling edge on serial data. JB RX.AB2 SJMP AB1 ;Go back and repeat sampling. ``` ## Automatic baud rate detection for the 80C51 ``` AB3: CLR TR0 ; Maximum sample time has expired, check result. CLR ;Begin by stopping timer and clearing flag. MOV BaudRate, #19 ; Set up table pointers. CmpLoop: MOV A, BaudRate VOM DPTR, #CmpTable MOVC A, @A+DPTR ;Get a table entry for comparison. DEC BaudRate CJNE A, CharH, Cmp1 ;Check result range. SJMP CmpLow ;High byte table = timed value, check low byte. Cmp1: JC CmpMatch ;A match if table value is < timed value. DJNZ BaudRate, CmpLoop ; Check for end of comparison table. SJMP CmpMatch CmpLow: VOM A, BaudRate MOVC A, @A+DPTR ;Get a table entry for comparison. CJNE A, CharL, Cmp2 ;Check result range. SETB C ;Match if equal. Cmp2: JC CmpMatch ;C set if A < low byte of result. DJNZ BaudRate, CmpLoop ; Check for end of comparison table. CmpMatch: MOV A, BaudRate ;Comparison complete, CLR С ; get final baud rate index, RRC MOV BaudRate, A ; and save. RET ; Compare table holds timer values for the transition points of the accepted baud rates. Entries are LSB, MSB. These values are for 12 MHz operation. CmpTable: DB 40h,0 ;0 - out of range, value too low. DB 80h,0 ;1 - 38400 baud. DB 0,01h ;2 - 19200 baud. DB 0,02h ;3 - 9600 baud. DB 0,04h ;4 - 4800 baud. DB 0,08h ;5 - 2400 baud. DB 0,10h ;6 - 1200 baud. DB 0,20h ;7 - 600 baud. DB 0,40h ;8 - 300 baud. DB ;9 - out of range, value too high. 0,80h END ``` # Determining baud rates for 8051 UARTs and other UART issues **AN448** Author: Greg Goodhue The purpose of this note is to expand upon and clarify some aspects of determining baud rates and crystal frequencies for using a standard 8051 or 80C51 UART for ordinary RS-232 type serial communication. The standard baud rate equation is simplified here and is restated to allow solving for other variables such as the crystal frequency and timer reload values. The following discussion assumes that the reader has some knowledge of the 8051/80C51 UART and timers. This should be considered a supplement to the information presented in the Phillips 80C51 Family Microcontroller Data Book sections on Timer/Counters and the Standard Serial Interface. Since this discussion assumes the use of a standard UART for RS-232 serial communications, the UART will be used in modes 1 or 3 (variable baud rates) and timer 1 will be used in mode 2 (8-bit auto-reload mode) as the baud rate generator. All of the equations shown here give an option for two clock divisors depending on whether the SMOD bit is used on a CMOS microcontroller. For an NMOS device, always use the default value (SMOD is not = 1). The basic equation for a timer reload value can be stated as: #### Example: To obtain a timer reload value for a 9600 baud serial data rate with an 11.0592 MHz crystal: $$256 - \frac{11,059,200/384}{9600} = 256 - 3 = 253$$ , or FD hexadecimal The equation can also be solved to derive the baud rate or the crystal frequency from the other information as follows: Minimum crystal frequency for a given baud rate $$=$$ Baud Rate $\times$ 384 (or 192 if SMOD = 1) Thus, the minimum crystal frequency that may be used for 19.2k baud communication on a CMOS part with SMOD = 1 would be $19200 \times 192$ , which gives 3.6864 MHz. When using this equation, the timer reload value TH1 for the maximum baud rate is always 255 (256 – 1) or FF hexadecimal. Of course, any even multiple of the frequency obtained in this manner will also support the same baud rate with a different timer reload value. For instance, four times 3.6864 MHz is 14.7456 MHz. At that crystal frequency, 19.2k baud is attained with a timer reload value that gives one fourth of the timer overflow rate: 252 (256 - 4) or FC hexadecimal. # Determining baud rates for 8051 UARTs and other UART issues AN448 ## CRYSTAL FREQUENCIES USED FOR STANDARD BAUD RATES The following chart shows possible crystal frequencies for use with the 80C51 UART at standard baud rates. The chart assumes use of the UART in modes 1 or 3 (variable baud rates) and timer mode 2 (8-bit auto-reload mode). The chart also assumes a minimum requirement of at least 9600 baud (including the use of SMOD for baud rate doubling). More crystal frequencies are available if a lower maximum baud rate is required. The minimum timer count column indicates how many timer counts are required at the stated crystal frequency in order to obtain the maximum baud rate shown. The last column shows the timer reload value that is used to obtain the minimum timer count. This is simply 256 minus the minimum timer count. Timer reload values for other baud rates at the same crystal frequency are determined by multiplying the minimum timer count by two successively and calculating a new reload value as previously mentioned. For instance, for 4800 baud at 1.8432 MHz, the timer count would be 2 (twice what it is for 9600 baud), giving a timer reload value of 254 (256 – 2) or FE hexadecimal. | Maximum Standard<br>Crystal (MHz) | Maximum<br>Baud Rate | Timer Count | Timer Reload<br>Value (in hex) | |-----------------------------------|----------------------|--------------------------------------------|--------------------------------| | 1.8432 | 9600 | <b>1</b> | FF | | 3.6864 | 19200 | 1, | FF | | 5.5296 | 9600 | 3 4 4 4 4 4 | FD | | 7.3728 | 38400 | ja ka ka ka ja k <b>a</b> jaky wasan ka ka | 94444 FF: 11 144 | | 9.2160 | 9600 | 5 | FB | | 11.0592 | 19200 | 3 | FD | | 12.9024 | 9600 | 7 | F9 | | 14.7456 | 76800<br>(2×38400) | 1 | FF | | 16.5888 | 9600 | | F7 | | 18.4320 | 19200 | 5 | FB | | 20.2752 | 9600 | 11 | F5 | | 22.1184 | 38400 | 3 | FD | | 23.9616 | 9600 | 13 | F3 | | 25.8048 | 19200 | 7 | F9 | | 27.6840 | 9600 | 15 | F1 | | 29.4912 | 153600<br>(4×38400) | 1 | FF | | 31.3344 | 9600 | 17 | EF | | 33.1776 | 19200 | 9 | F7 | | 35.0208 | 9600 | 19 | ED | | 36.8640 | 38400 | 5 | FB | # Determining baud rates for 8051 UARTs and other UART issues AN448 # THE EFFECT OF USING OFF-FREQUENCY CRYSTALS Occasionally, one may wish to use an off-frequency crystal in a design, but still want to make use of the UART for debug purposes. Since most terminals (or other RS-232 devices) will communicate with another device that has a baud rate that is off by several percent, this can often be done successfully. WARNING: running the UART off-frequency is NOT recommended if part of the application's normal operation involves communication with other RS-232 devices. There is no exact limit on how much frequency error is tolerable, since this depends on the devices communicating, the baud rates, precise frequencies used by both devices, etc. However, a rule of thumb may be used that the communication is likely to work if the frequency is off by less than 5%. This somewhat arbitrary number was arrived at as follows: for a ten-bit serial code (one start, 8 data bits, one stop), a 10% data rate error will put the receiver off by about plus or minus one bit time at the end of one data frame. A one bit-time error seems rather excessive if one wants fairly reliable communications. So, consider using half of that value (5%) as a rule of thumb. The consequence of all this is that one may often find a more standard "off-the-shelf" crystal frequency to use in an application, if the UART is being used for debugging, factory testing, etc. As an example, consider the well-known "color burst" crystal. At 3.579545 MHz, this crystal is only about 3% slower than the 3.6864 MHz crystal that may be desired for baud rate generation. As such, this lower cost crystal could be used in place of the less standard one in some cases. Another obvious replacement is to use the standard 14.31818 MHz crystal in place of the not-so-standard 14.7456 MHz crystal that appears in the table. This replacement also yields a less than 3% error and may be handy because it gives a fast instruction execution rate for the 80C51, whereas 3.58 MHz may be too slow for many applications. It should also be remembered that RS-232 communications are most robust if characters are not transmitted back-to-back. This can become more important when the UART is deliberately used out of spec as described here. When data is sent at full speed, there is no chance for the receiver to re-synchronize to the transmitted frames if it once gets out of synch. However, when there is a short pause between characters (about 2 to 3 bit times or longer), the receiver will generally be able to correctly locate start bits without framing errors. In the worst case, a pause of one byte-time or longer in a transmission should ALWAYS re-synchronize any receiver no matter how out of synch it has become. #### A LITTLE KNOWN PHENOMENON In the UART setup code for most applications, the actual timer count register (TL1) is not initialized. In many applications, this DOES have an affect on the way the UART behaves on the first character sent, although the chances of this being noticed are slight. This can be seen by trying to observe the first character sent from the UART on a logic analyzer that is being triggered by the end of microcontroller reset. The first character will begin so far down the time line that it will not be seen at any resolution on the logic analyzer that would show any of the individual bits. This effect occurs because TL1 has to time-out once before the first character is transmitted. If TL1 is not initialized in the program, it will have a reset value of 0. This could give the first timeout a duration of up to 255 normal bit times, depending on the reload value for TH1 (which again depends on the baud rate and crystal frequency). Again, in most applications, this would never be an issue. In fact, it may often be an advantage to have a delay before the first serial character is sent after power-up. But if the first serial character should start sooner, TL1 may be initialized to some value other than zero. For no delay, the same value used in TH1 should be used. June 1993 647 **ESG89001** #### 1. INTRODUCTION The routing of the traces on a Printed Circuit Board (PCB) largely effect the ElectroMagnetic Compatibility (EMC) performance of the PCB with respect to both ElectroMagnetic (EM) radiation as susceptibility to EM-fields. The PCB will connect electronic components such as passive components, transistors and ICs. Furthermore, cables to interconnect the PCB with other system parts, e.g., another PCB, signal generator, CATV wall-outlet, DC power source or an AC-mains connection, will largely influence the PCB with respect to EMC [7]. In order to get a PCB on which the circuits function properly, the trace routing, the placement of components/connectors and the decoupling used with certain ICs will have to be optimized according to the constraints given in this report. To reach an economic and functional PCB design, the following items have to be kept in mind: - Correct choice of the PCB format (mono, bi- or multi-layer) - Take care that "every" signaltrace has its signalreturn nearby - Proper decoupling for each IC or group of ICs - Allowed tracelengths and allowed loopareas - 8. Placement of the connectors - Right cable choice with a proper connector - 10. Proper use and placement of filters and filterparts. These items with the appropriate measures will be further explained. The main target is to get control over your PCB currents. #### 2. GENERAL ### 2.1. Conductors Single conductors have, as a rule of thumb, an inductance of $1\mu H/m$ . At low frequencies only, below 1kHz, $R_{dc}$ applies. These impedances, together with the currents that will flow through these impedances, will be responsible for the voltage drop between points as Ohms law applies. The voltage drop can be diminished by either reducing the impedance or lowering the current through that impedance. In typical digital designs the voltage drop will be frequency independent. A square wave current, resulting from a square wave output voltage to a resistive load, can be described as a series of sinewaves of which the amplitude of the harmonics decrease proportional with the frequency (Fourier expansions), see Figure 1b. The impedance of the inductor increases proportional with frequency (see Figure 1a), therefore the product; voltage drop (Figure 1c) remains constant. When the current has a triangular waveshape, as function of time, due to capacitive loading, the amplitude of the harmonics decreases with the frequency square and the voltage drop across the inductor reduces proportional with frequency. #### 2.2. Transmissionlines By using the inductance of a single wire, $L_i$ , the mutual coupling, M, and the capacitance between the traces, $C_i$ , a transmissionline, shown in Figure 2, can be defined of which the characteristic impedance, $Z_O$ , equals: $$Z_O = \sqrt{(L_{eff}/C)}$$ where $$L_{eff} = L_1 + L_2 - 2 \cdot M$$ , $k = \sqrt{(L_1 + L_2)} / M$ and $C = C_1 + C_2$ . When the coupling, k, between the traces of the transmissionline is high, the effective inductance will decrease rapidly. Some coupling factors are given in Table 1. An indifferent signal path design (Figure 3a) can be changed into a transmissionline design (Figure 3b). This change will lower the effective inductance, $L_{\rm eff}$ , between the two circuit blocks and will therefore lower the voltage drop between the two references of those circuits. Table 1. Coupling Factors between the Conductors of a Transmissionline | TRANSMISSIONLINE<br>TYPE | COUPLING | | | | | | |--------------------------|------------|--|--|--|--|--| | Parallel wires | 0.5 – 0.7 | | | | | | | Bi-layer PCB | 0.6 – 0.9 | | | | | | | Multi-layer PCB | 0.9 – 0.97 | | | | | | | Coaxial cable | 0.8 – 1.0 | | | | | | | RG-58 coax | 0.996 | | | | | | ## ESG89001 elements # 2.3. Capacitive and Inductive Coupling Separately, the capacitive and inductive values, derived from the definition of the transmissionline, can also be used to calculate the crosstalk between adjacent traces, not being a function signal path. The capacitive coupling, representing and induced current, is given by: $I_{Ck} = 1/Ck \cdot dV/dt$ where. C<sub>k</sub> = coupling capacitance between adjacent traces; in practice: 100pF/m (depends upon the vicinity of other traces, see Appendix A), and the inductive coupling, representing an induced voltage, is given by: $V_{Mk} = Mk \cdot dl/dt$ where: $M_k$ = mutual coupling between two traces (For further detail see Chapter 4.) In both coupling modes, the transfer function will typically show a high pass behavior. # 3. CHOICE OF THE PCB-MATERIAL By a proper choice of the PCB-material and the routing of the traces, a good transmissionline with low coupling to other traces can be created. Low coupling, or little crosstalk, can be obtained when the distance, d, between the transmissionline conductors is less than their distance to other adjacent conductors (see Figure 4). By using these examples of geometry of traces the definition of the transmissionline between S1, S2, Si, j and (S2) GND, $V_{EE}$ and/or $V_{CC}$ are well defined and the coupling between the traces S2 and S1 is low. ESG89001 The most economic PCB format has to be chosen based on: - the legal and/or functional EMC requirements for the product, - trace density, - assembly and manufacturer capabilities, - CAD-system capabilities, - design-costs, - PCB quantities, and - the costs of EM-shielding Special attention must be given to the integral costs (components packaging/pinning + PCB-format + EM-shielding + construction + assembly) when a product definition is considered by using a NON-shielded cover. In many cases the choice of a proper PCB-format may expel the need for a metallized box within the plastic cover. To improve immunity and to lower unwanted emission, both in fast analog and all digital applications, transmissionlines are needed. Dependent upon the transition of the output signal, a transmissionline needs to be present between $S \leftrightarrow V_{CC}$ , $S \leftrightarrow V_{EE}$ , and $V_{EE} \leftrightarrow V_{CC}$ , as indicated in Figure 5. The signal current will be determined by the output-stage symmetry of the circuit. For MOS: $I_{OL} = I_{OH}$ , while for TTL: $I_{OL} > I_{OH}$ . The Logic Family and functional reasons determine the typical characteristic impedance, Z<sub>O</sub>, for that transmissionline which is given in Table 2. Table 2. The Transmissionline Impedances, Z<sub>O</sub>, for Several Signal Paths | Coverar Orginar r atms | | | | | | | |------------------------|---------------------------|--|--|--|--|--| | FUNCTION/LOGIC | <b>Z</b> <sub>O</sub> (Ω) | | | | | | | Supply (typ.) | <<10 | | | | | | | Signal ECL | 50 | | | | | | | Signal TTL | 100 | | | | | | | Signal HC(T) | 200 | | | | | | For two traces next to each other the following formula applies [10, 11]. $$Z_{O} = \frac{120 \ln(\pi.h/(b+c))}{\sqrt{\epsilon} r}$$ where h = distance between traces b = width of the trace c = thickness of the trace; typical 17µm, for two traces on top of each other: $$Z_{O} = \frac{120 \pi (h/(h + b))}{\sqrt{\epsilon} r}$$ where: h = 1.5mm (typical thickness of epoxy). When the trace is above a goundplane the following formula applies: $$Z_{O} = \frac{87 \ln(6.h/(.8.b + c))}{\sqrt{(\epsilon_{r} + \sqrt{2})}}$$ and in case of a trace between two (ground-) planes the formula yields: $$Z_{O} = \frac{60 \text{ In } (4.\text{K/}(.67.\pi.\text{b.}(.8 + \text{c/b})))}{\sqrt{\epsilon} r}$$ where K = distance in-between the planes. Typically the permittivity for epoxy material equals: $\varepsilon_r = 4.7$ . ### THE SIGNALTRACE AND ITS SIGNALRETURN Signaltraces need to have their signal-returntraces as close as possible in order to prevent emission from that looparea enclosed by these traces and to reduce susceptibility due to voltages which can be induced in this loop, e.g., by RF-transmitters and ESD. Commonly, when the distance between two traces equals the width of the traces, the coupling factor is about 0.5 to 0.6. The effective inductance of the traces has gone down from 1µH/m to 0.4 – 0.5µH/m. This means that 40 to 50% of the signal-return current may run freely through the other traces of the PCB. For each signal path between two (sub-)blocks either analog or digital **three** properly defined transmissionlines need to be present with the impedances given in Table 2 and shown in Figure 5. With TTL logic the sink-current; the high-to-low transition, is higher than the source-current. In this case the transmissionline should be defined between $V_{CC}$ and S instead of $V_{EE}$ and S, which is commonly considered. June 1989 650 ESG89001 The mutual coupling between two parallel traces can be calculated from the double integral [9]: $$M_k = \mu/(4.\pi). \int_{1_1} \int_{1_2} d\underline{s} 1.d\underline{s} 2.d\underline{r} / |\underline{r}|$$ where: $l_1$ , $l_2$ = length of traces 1 and 2 $\underline{r}$ = relative distance between line segments, $\underline{d}\underline{s}$ 1, $\underline{d}\underline{s}$ 2, of each trace. Substituting the geometry of two parallel lines results in: $$M_{k} = 200 [I.ln {(I+ \sqrt{(I^{2}+h^{2})}) / h} + \sqrt{(I^{2}+h^{2}) + h} ][nH]$$ where: I = length of the two parallel traces and h = distance between the traces (trace thickness and width are neglected). If the coupling between the two conductors of a transmissionline is too low, a ferrite toroid $(\mu_r > 200 \ (-5000))$ , with some windings, will increase this coupling to $\cong 1$ . By using ferrite toroids one can get full control over the signal- and signal-return currents. In case of parallel conductors, the characteristic impedance of this transmissionline may be influenced by the ferrite. In case of coaxial cable, the presence of the ferrite will only be noticeable on the outer parameters of the cable. #### **CONCLUSIONS:** - Use traces as thin as possible next to one another instead on top of each other (separation commonly less than 1.5mm + epoxy thickness of a bi-layer). - Create a layout where every signalline has its signal-return at the closest possible interval (applies to both signaland supply-traces). - III. If the coupling between the conductors of the transmissionline is insufficient a ferrite toroid may be used. # 5. PROPER DECOUPLING WITH EACH IC ICs will be commonly decoupled by capacitors only. Because capacitors are not ideal, resonances will occur. Above the resonance frequency the capacitor behaves as an inductor, which means that the dl/dt is limited. The value of this capacitor is determined by the voltage-fluctuations which are allowed across the power supply pins of the IC. According to good designers practice, this voltage fluctuation should be less than 25% of the signal-line worst-case noise margin. From the following equation the optimal decoupling capacitor for each logic family output gate can be calculated: I = c.dV/dt The worst-case signal-line noise margins for several logic families are given in Table 3, together with the recommended decoupling capacitor value, $C_{\text{dec.}}$ , which need to be added with each output gate. The values of the decoupling capacitors for fast logic families may no longer be useful if the capacitor incorporates a large series inductance, either caused by the construction of the capacitor, long connecting wires or PCB traces. Additional small ceramic capacitors (100–100pF) need then to be added, as close as possible to the pins of the IC, in parallel to these "LF-" decoupling capacitors. The resonance frequency of this ceramic capacitor (including the trace length towards the supply pins of the IC) should be above the bandwidth of the logic [ $1/(\pi.\tau_r)$ ], where $\tau_r$ is the voltage risetime of the logic. If the decoupling capacitor is placed with every IC the signal return current may choose which path is most convenient, $\rm V_{EE}$ or V<sub>CC</sub>. This choice is determined by the mutual coupling present between the signal trace and one of the supply traces. Between two decoupling capacitors, one for each IC, and the inductance, L<sub>trace</sub>, formed by the supply traces, a series resonant circuit will result. This resonance is only allowed when it occurs at low frequencies (<1MHz) or when the Q of this resonance circuit is low (<2). This resonance can be kept below 1MHz by using a choke with high RF-losses in series with the V<sub>CC</sub> network and the decoupled IC. Too less RF-losses can be compensated by either adding a resistor in parallel or in series (Figure 6). **Table 3. Recommended Decoupling Capacitor** | FAMILY NOISE-MARGIN | | | di . | C <sub>dec.</sub> | | | |---------------------|---------|------|-------|-------------------|-------|------| | | | volt | 1.4.5 | mA | ns | nF | | CMOS (5V) | | 1.75 | | 2 | 100 | 0.5 | | TTL-LS | 1000000 | 0.4 | | 50 | 10 | 5.0 | | TTL-F | | 0.4 | | 50 | 2-3 | 22.0 | | нст | | 0.7 | | 50 | 2-3 | 12.8 | | HC (5V) | | 1.2 | | 50 | 2-3 | 7.5 | | ACT | | 1.7 | | 175 | 1 – 2 | 35.0 | ESG89001 The choke may never have an open core, because then it will either act as a RF-transmitter or a ferroceptor for magnetic fields. #### Example: $$\begin{array}{c} 1 MHz \times 1 \mu H \rightarrow Z_1 = 6.28 \Omega \rightarrow R_8 = \ 3.14 \Omega \\ Q \leq 2 \qquad \qquad R_p = \end{array}$$ $12.56\Omega$ Above the resonance frequency, the characteristic impedance, $Z_{\rm O}$ , of the "transmissionline" (in this case the impedance of the IC sees at its supply terminals) will be equal to: $$Z_O = \sqrt{(L_{trace} / C_{decoupling})}$$ . The series inductance of the decoupling capacitor and the inductance of the interconnecting traces have a negligible effect on the RF supply-current distribution, when a choke of 1 $\mu$ H, for example, is used. Still it determines the voltage fluctuations between the supply pins of the IC. With a 25% signal-to-noise margin dissipation by the power supply, the recommended maximum inductances, $L_{trace}$ , are given in Table 4. With the decoupling as suggested in Figure 6, the number of transmissionlines between the two ICs has gone down from 3 to 1 (see Figure 7). ### CONCLUSION: IV. By using proper decoupling with each IC: L<sub>choke</sub> + C<sub>dec.</sub>, only one transmissionline needs to be defined between the circuit blocke. With high speed logic, $\tau_r$ < 3ns, the total inductance in series with the decoupling capacitor needs to be low (see Table 4). A trace, in series with the supply pins, of 50mm equals an inductance of 50nH. Together with the load conditions at an output, 50pF typical, this will give a minimum risetime of 3.2ns. If faster risetimes are required, shorter leads from the decoupling capacitor (preferred leadless) and shorter leads within the IC package are necessary. This can be obtained by using, for example, IC-decoupling capacitors, or better, using center (supply) pinned ICs in combination with small leadless ceramic capacitors with a 3E pitch (DIL). A multi-layer board with supply and ground planes can be another option. Further improvements can be reached by applying SO-packages with center pinned supply connections. #### CONCLUSION: When using fast logic: multi-layer panels should be used. Table 4. Allowed (Supply) Series Inductance | FAMILY NOISE-MARGIN<br>volt | | | dl/dt<br>mA | ns | L <sub>trace</sub><br>nF | |-----------------------------|------|--------|-------------|-------|--------------------------| | CMOS (5V) | 1.75 | 4,7.42 | 2 | 100 | 200.0 | | TTL-LS | 0.4 | | 50 | 10 | 20.0 | | TTL-F | 0.4 | | 50 | 2-3 | 4.0 | | HCT | 0.7 | | 50 | 2-3 | 7.0 | | HC (5V) | 1.2 | | 50 | 2-3 | 12.0 | | ACT | 1.7 | | 175 | 1 – 2 | 2.4 | # ESG89001 # 6. MINIMIZE TRACELENGTH AND LIMITED LOOPAREAS The maximum tracelength is determined by reflections which will occur at NON-terminated transmissionlines. The loopareas and tracelengths are limited by the EM-radiation which is allowed by mandatory requirements for the product. The latter requirements will directly apply to the PCB if it is used in an unshielded box/cover. ### 6.1. Allowed Tracelengths Due to Reflections The first limitation of the tracelength is determined by functional requirements. A transmissionline can be made reflection free by either adding a load resistor at the end of the line, which without series capacitance will cause DC-dissipation, or by adding a resistor in series with the driver. In this case the output impedance of the circuit plus the series resistor must be equal to the characteristic impedance of the transmissionline. When the transmissionline is NOT terminated the allowed trace length is determined by the noise-margin of the logic used, its bandwidth and the propagation delay of the line, which is assumed to be 5ns/m. The bandwidth determines the dynamic noise margin which by approximation is inverse proportional to the disturbance pulse halfwidth time. Applying the requirement that the noise, in this case the reflected signal, has to be less than 25% of the (dynamic) noise margin the tracelengths in Table 5 result. #### CONCLUSION: VI. A transmissionline should, if necessary, be series-terminated at the drivers side. If the trace lengths are long compared to those given in the table, END-termination is inevitable. ### 6.2. Allowed Loopareas Due to Radiation The emission from a PCB (or a complete product) is limited to $100\mu Vm$ at 10 meters distance from the object at frequencies above 30MHz [FCC, IEC CISPR publications, class B]. This emission is determined by the product of the looparea, A, the loopcurrent, I, and the permeability of the medium within that loop, $\mu_{r}$ (commonly equal to 1). This product is called the magnetic dipole-moment, M. In case a number of loops are present, operating at the same frequency or clock-rate, the limit of the dipole-moment strength should be divided by $\sqrt{(n)}$ , in which n = number of loops, hence the signals will add as random noise. $$M(freq) = I(freq) \cdot A \cdot \mu_r$$ The limit value for the magnetic dipole-moment can be calculated from the radiated power [7, 8]: $$E = (7/r) \cdot \sqrt{(P_{rad})}$$ $$P_{rad} = 31200 . I^2 . A^2 / \lambda^4 = 31200 . \underline{M}^2 / \lambda^4$$ #### where: I = loopcurrent as function of frequency A = looparea λ = wavelength belonging to the frequency component of the loopcurrent By substitution the following results: $$E = (7/r) . 176 . I.A / \lambda^2$$ Filling in the requirement, given above, that $E \le 100 \mu V/m$ at 10 meters distance from the source the following equation results for the looparea and current as function of frequency: I.A / $$\lambda^2 \le 8.1~10^{-7}$$ [ A ], or $M \le 8.1 \ 10^{-7} \cdot \lambda^2 [A.m^2]$ Table 5. Allowed NON- or Series-Terminated Tracelength | FAMILY NOISE-MARGIN | | E-MARGIN dt | | MAXIMUM TRACELENGTH (m) | | | |---------------------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | | | | SERIES TERMINATED | | | | CMOS | 1.75 | 100 | 14.3 | to the second of | | | | TTL-LS | 0.4 | 10 | 0.4 | 0.5 | | | | TTL-F | 0.4 | 2-3 | 0.08 | 0.15 | | | | HCT | 0.7 | 2-3 | 0.14 | ∞ | | | | HC | 1.2 | 2-3 | 0.24 | <u>_</u> 1 | | | | ACT | 1.7 | 1-2 | 0.18 | 1. | | | #### NOTE: If series termination is used in an asynchronous logic circuit design, attention must be given to the occurrence of metastability; especially symmetrical logic input-circuitry cannot decide whether the input signal is high or low and a non-defined output status may/will result. ESG89001 The spectral current amplitude, for logic signals in the frequency domain, decrease above the bandwidth of the logic (= $1/\pi.\tau_t$ ) proportional with frequency square. At this corner frequency, the radiation resistance of the loop still increases proportional with frequency square. Therefore one can calculate the maximum looparea which is determined by the clockrate or repetition rate, the risetime or bandwidth of the logic and the current amplitude in the time-domain. The current waveshape is derived from the voltage waveshape and the current halfwidth time is by approximation equal to the voltage risetime (Figure 9). The current amplitude at the corner frequency (=1 / $\pi$ . $\tau_r$ ) becomes: $I(f) = 2.1.\tau_r / T$ #### where: I = current amplitude in the timedomain, T = 1 / clockrate = period time, $\tau_r$ = voltage risetime $\cong \tau_H$ current halfwidth time. From this equation the maximum looparea at a clockrate for a certain logic family can be calculated. These loopareas are given in Table 6. #### **CONCLUSION:** VII. The maximum looparea is determined by the clockrate, the logic family (= output current) and the number, n, of simultaneous switching loops on that PCB. When a bi-layer is used with a thickness of 1.5mm, the maximum allowable tracelength, derived from the looparea, will be much less than the tracelength found from the reflection point of view. If clockrates are used above 30MHz, the use of a multi-layer will be inevitable. In this case the epoxy thickness depends upon the number of layers used and may vary between 60 – 300µm. When only a limited number of high clockrate signals are distributed on the PCB, careful routing, by using side-to-side traces, may lead to acceptable results on a bi-layer. Table 6. The Allowed Single Looparea for Each Logic Family | FAMILY | dl | dt | MAXIMUM LOOPAREA IN mm <sup>2</sup> AT CLOCKRATE OF: | | | | |--------|------|-------|------------------------------------------------------|---------------------|-----------|-------------| | | mA . | ns | f = 4MHz | f = 10MHz | f = 30MHz | f = 100MHz | | CMOS | 2 | 100 | 4.5 10 <sup>6</sup> | 1.8 10 <sup>6</sup> | | | | TTL-LS | 50 | 10 | 1.8 10 <sup>6</sup> | 7200 | 2400 | | | TTL-F | 50 | 2-3 | 1.8 10 <sup>6</sup> | 1400 | 480 | 144 | | HCT | 50 | 2-3 | 1.8 10 <sup>6</sup> | 1400 | 480 | 144 | | HC | 50 | 2-3 | 1.8 10 <sup>6</sup> | 1400 | 480 | 144 | | ACT | 175 | 1 – 2 | 515 | 206 | 69 | 21 (note 1) | #### NOTE: In this case, when using common DIL packages, the looparea limit will be exceeded and additional shielding measures, together with proper filtering will be inevitable. # ESG89001 ### 6.3. Allowed Tracelength Due to Radiation The allowed tracelength are even less, when the transmissionline is directly coupled to the system reference and an unshielded outgoing cable leaving the product, then the values found up to now. A simple diagram is given in Figure 10. The voltage drop between the two references with each IC has become the driving source of the antenna formed by reference system and the outgoing cable. The worst case radiation resistance of the antenna is assumed to be $150\Omega$ and frequency independent [7]. The amplitude of the driving source, U, is now limited to: $$P_{rad} = U^2 / 150\Omega$$ . Applying the radiation requirements as given earlier the voltage drop has to be: U ≤ 1.75mV. The voltage drop is determined by the current amplitude, at the logic bandwidth's frequency, and the effective inductance of the transmissionline between these points. $$U(f) = I(f).Z(f) = I(f).j.\omega.(L-M) = I(f).j.\omega.L.(I-k)$$ Taking Table 1 and the current amplitude in the frequency domain, the tracelengths in Table 7 can be found. This table shows that many practical applications shall not fulfill the radiation requirements. In most cases, filtering or shielding of the outgoing cable, which leaves the product will be sufficient. Shielding of the entire product, plus necessary filtering, becomes inevitable when the magnetic loop constraints are exceeded. ### CONCLUSION: VIII. Circuit designs shall be made in such a way that the voltage drop between references shall not directly excite an antenna being any outgoing cable. Simple approximations will give the number for the required filtering or shielding performance whenever necessary. These can be found by using the Tables 6 and 7 and counting the number of correlated sources in the product. In the chapters 7, 8, and 9 some basic information is given about the cable shield performance and filtering techniques. Table 7. Maximum Tracelength in Case of Direct Radiation | FAMILY | di | dt | ALLOWED TRACELENGTH IN mm<br>BI-LAYER / MULTI-LAYER | | | | |--------|-----|-----|-----------------------------------------------------|--------------|--------------|----------------| | | mA | ns | f = 4MHz | f = 10MHz | f = 30MHz | f = 100MHz | | CMOS | 2 | 100 | 108 / — | 44 / — | | | | TTL-LS | 50 | 10 | 4.3 / — | 1.75/— | 0.6/— | <u></u> | | TTL-F | 50 | 2-3 | 4.3 / 55 | 1.75 / 40 | 0.6 / 4.4 | <b>— / 2.2</b> | | HCT | 50 | 2-3 | 4.3 / 55 | 1.75 / 40 | 0.6 / 4.4 | <b>— / 2.2</b> | | HC | 50 | 2-3 | 4.3 / 55 | 1.75 / 40 | 0.6 / 4.4 | <b>—/2.2</b> | | ACT | 175 | 1-2 | <b>—/ 15.4</b> | <b>—/3.2</b> | <b>—/2.1</b> | <b>/0.62</b> | ESG89001 # 7. PLACEMENT OF THE CONNECTORS All connectors, which provide the interconnections to other panels and/or units, must be placed as close as possible to one another. In this way common-mode currents, which are induced in those cables, will NOT flow through the traces of the circuit on the PCB. In addition, voltage drop between references on the PCB will not excite the (antenna)-cables. To avoid such common-mode effects, it may be necessary to make a separation between the reference-strip near to the connectors and the groundplane, groundgrid or reference of the circuitry on the PCB. This groundstrip shall, if applicable, be connected to the metal cover of the product. From this separate groundstrip, only high impedances; inductors, resistors, reed relays and opto-couplers are allowed in between these two grounds. This will be explained when the filter networks are described, Chapter 9. #### **CONCLUSION:** IX. All connectors need to be placed as close as possible to one another in order to prevent external currents running through the traces or reference of the PCB. ## 8. RIGHT CABLE CHOICE WITH A PROPER CONNECTOR Cables have, when they are shielded, a transferimpedance, see Appendix B. Determined by the amplitude and the frequency content of the signals flowing through these cables a choice shall be made. In case cables, leaving the enclosure of the product, contain data above a 10kHz clockrate, shielding will be inevitable (product requirement). This shielding shall be connected to ground (metal cover product) on both ends of the cable, this to assure that the shield acts both as an electric and a magnetic shield. If separate grounds are used, this shall be done to the "connector-ground" instead of the "circuit-ground". In case the clockrate is above 10kHz and below 1MHz and the risetime of the logic is kept as slow as possible, an optical coverage of 80% or more or a transferimpedance which equals less than 10nH/m will do. Above 1MHz clockrates, better shielded cables are always necessary. In general, coaxial cable excluded, the shield of the cable shall not be used as signal return. By using passive filters in series with the signal input/outputs to the ground/reference, to reduce the RF-content, the necessity of a high quality shielding and the corresponding connector can be avoided. A proper shielded cable will have a transferimpedance equal to or less than $|j.\omega.10 \text{ nH/ml}|$ . Every wire has an inductance of 1 nH/mm (refer to chapter 2.1.). In case the shielding of such a cable is wrapped into a pigtail, the inductance of that pigtail will degrade the shielding performance, thus increase the transferimpedance, of the cable. #### **CONCLUSION:** A good shielded cable deserves a proper connector. # 9. PROPER USE AND PLACEMENT OF FILTERS AND FILTER PARTS Signal bandwidth reduction shall be achieved by using RC low-pass filters. In case the voltage drop across the series resistor is unacceptable an inductor with high RF-losses shall be used. The LC low-pass filter will always show resonances and therefore its Q must be kept low. The filter can be used in two directions; namely, to prevent emission from the PCB and to improve the immunity of the board to external sources, e.g. RF-transmitters, ESD, etc. The lay-out of the interconnection of the shield of the cable and a low-pass RCR-filter is given in Figure 12. The lay-out of the filter shall be such that the requirements for the maximum tracelength, Table 7, are not violated. #### **CONCLUSIONS:** - Currents, which do not belong to the circuit signals, should be by-passed using another path. - XII. The bandwidth of signals should be limited to the lease functional bandwidth. Use the slowest logic family suitable for the function. Philips Semiconductors Application note # Electro magnetic compatibility and printed circuit board (PCB) constraints ESG89001 ### 10. PCB DEMO-BOARD, ROUTING AND DECOUPLING EFFECTS An EURO-card PCB $(100 \times 160 \text{ mm}^2)$ has been chosen to demonstrate the effects of signallines and their signal returns with respect to magnetic radiation. The board contains a relaxation oscillator, created by 3 inverters (NANDs) and an RC-network (1kΩ, 560pF), which will produce a squarewave voltage signal. The frequency will be determined by the used logic and its threshold voltages. This oscillator is placed in one corner of the board together with some switches to change signal-return path and supply decoupling. In the opposite corner of the PCB another quad NAND has been placed as a capacitive load. These NANDs are all cascaded and will change status with some skew. The last NAND is terminated by a resistor. The supply decoupling of this IC can be altered as well. The diagram of the circuit with the switches is given in Figure 13 and the physical layout of the PCB and component placement are given in Figure 14. The layout has been chosen such that the supply traces are as close as possible to one another, which is commonly arranged by a proper CAD-tool. In parallel to the signaltrace a signalraturn trace has been placed, according to Chapter 4. At the supply pins of the ICs decoupling capacitors are added to each IC. By means of jumpers or switches a series inductor may be short-circuited or added to the circuit. In total 4 relevant situations can be evaluated which are given in Table 8. #### Situation 1 Supply decoupling only takes place by the capacitors and the signal return has been established through the supply trace $V_{EE}$ ( $V_{DD}$ ). #### Situation 2. Supply decoupling only takes place by the capacitors and the signal return has been established through the supply trace $V_{\rm EE}$ ( $V_{\rm DD}$ ) and a trace in parallel to the signal trace. The coupling between signal and signal return determines that only a small portion of the signal-return current will flow through the supply traces. #### Situation 3. The supply trace, $V_{EE}$ ( $V_{DD}$ ), has been taken out and the $I_{CC}$ and signal-return current have to flow through the trace next to the signalline. The high frequency components of the signal-return current shall still flow through the $V_{CC}$ ( $V_{SS}$ ) trace due to the (de-)coupling capacitors at the supply pins of the ICs. #### Situation 4. By adding the inductors, with sufficient RF-loss, in series with the supply trace, V<sub>CC</sub>, of both ICs *ALL* the signal-return current will have to flow through the trace next to the signalline and radiation from the loop on the PCB has diminished. The effects with respect to the radiation can be measured both in time as in frequency-domain. The latter has the advantage of showing the differences between situation 3 and 4 which are marginally discernable on an oscilloscope. These RF-effects are of extreme importance with respect to radiation as explained in Chapter 6. To demonstrate the phenomena on an oscilloscope, a 50 (100) MHz bandwidth version shall be used. A small (electrically shielded) loop shall be used as measuring probe. If not available, a loop made by using a voltage probe of which the ground strap is short-circuited to the measuring tip can be used. This "loop" shall be placed on the PCB as some secondary loop near the supply traces. On the oscilloscope the effects of the positions of the switches can be observed. Measured results in the time domain are given in Appendix C. In case a spectrum analyzer is used, an electrically shielded measuring loop shall be placed on the PCB as some secondary loop near the supply traces. On the screen the effects of the positions of the switches can be observed. Measured results in the frequency domain are given in Appendix D. Table 8. A List of the Relevant Configurations of the Switches on the Demo-board with Respect to Emission Measures. | POSITION OF THE SWITCHES | | | | | | | |--------------------------|------|------|------|------|--|--| | SITUATION | SW 1 | SW 2 | SW 3 | SW 5 | | | | 1 1 | ON | ON | ON | OFF | | | | 2 | ON | ON | ON | ON | | | | 3 | OFF | ON | ON | ON | | | | 4 | OFF | OFF | OFF | ON | | | June 1989 657 Philips Semiconductors Application note # Electro magnetic compatibility and printed circuit board (PCB) constraints ESG89001 The behaviour of the PCB has been simulated with PHILPAC for a unity sinewave signalsource and the sum of the currents through the $V_{EE}$ and $V_{DD}$ traces are given in Figure 15. In the simulated circuit the parasitic capacitance across the chokes has been taken into account, which leads to the same result at higher frequencies with respect to situation 3 and 4. As long as the measuring loop is kept from the oscillator area, which itself (also due to the switches) radiates the effects can be shown unambiguously. #### **REMARK:** As radiation from a certain passive network is reciprocal, the same results could have been obtained in case of an immunity set-up. June 1989 658 659 ESG89001 ESG89001 #### 11. REFERENCES - [1] EMC in TV receivers and monitors, D. Teuling, ETV 8702 Philips Components, 1987, Eindhoven. - [2] Electromagnetic compatibility syllabus, J.J. Goedbloed, November 1987, Philips Central Training Department, The Netherlands. - [3] Low frequency approach to the electromagnetic radiation of the printed circuit boards, M. Coenen, Philips Research Lab. Note 316/85. - [4] Radiated emissions from common-mode currents, C.R. Paul, IEEE EMC symposium notes, 1987. - [5] EMC and loop inductances on printed wiring boards, B. Danker, 7th Symposium on EMC, Zurich, 1987. - [6] Electromagnetic compatibility design and layout guidelines of printed circuit boards, M.J.C.M. van Doorn, Philips Video Display Products, Pre-development, AR6-60.07, 1987. - [7] An evaluation method to characterize the EMC performance of PCBs containing ICs, M.J. Coenen, ESG 8801, Philips Components, 1988. - [8] Antenna theory, analysis and design, C.A. Balanis, Harper and Row Publishers, New York, 1982. - [9] Electromagnetic theory, J.A. Stratton, McGraw Hill, New York and London, 1941. - [10] Fast TTL Logic series, Handbook IC15 Philips, 1988. - [11] Advanced CMOS Logic Data Manual, Signetics/Philips, 1988. - [12] Taschenbuch der Hochfrequenztechnik, H. Meinke, F.W. Gundlach, Springer Verlag, Berlin, New York, 1968. - [13] Transmission-line methods aid memory-board design, E.A. Burton, Electronic Design, December 1988. - [14] EDN's advanced CMOS logic ground-bounce tests, EDN, March 1989. ESG89001 # APPENDIX A. CAPACITIVE COUPLING BETWEEN TRACES In this appendix the graphical presentation is given of the capacitive coupling between two traces in free space and for two traces above a reference plane [12, form. 24.25]. It shows the necessity of a reference plane at a height, h, closer to the traces than the distance, D, to reduce the capacitive coupling between the traces. ESG89001 ### APPENDIX B. THE TRANSFER IMPEDANCE OF VARIOUS CABLE SCREENS The transfer impedance, Z<sub>1</sub>, is the relation between the current through the screen due to an external source and the induced voltage across the nominal load impedances of that cable. Further information about the measuring method to obtain information of the screening efficiency or the transfer impedance can be found in IEC publication 96. ESG89001 APPENDIX C. MEASURED RESULTS IN THE TIME DOMAIN, 150MHz BANDWIDTH, FROM THE DEMO-BOARD, CONTAINING A 74HCT00, IN THE 4 CONDITIONS DESCRIBED IN CHAPTER 10. APPENDIX D1. MEASURED RESULTS IN THE FREQUENCY DOMAIN, PEAK DETECTION, FROM THE DEMO-BOARD, CONTAINING A 74HCT00, IN THE 4 CONDITIONS DESCRIBED IN CHAPTER 10. June 1989 665 ESG89001 APPENDIX D2. MEASURED RESULTS IN THE FREQUENCY DOMAIN, PEAK DETECTION, FROM THE DEMO-BOARD, CONTAINING A 74HCT00, IN THE 4 CONDITIONS DESCRIBED IN CHAPTER 10. **EIE/AN91001** #### 1 INTRODUCTION In many mass manufactured electrical and electronic products, printed wiring boards (PWBs) are used in a non-shielded application because it would be too expensive to do otherwise, e.g. handheld cassette players, telephones, televisions, etc. As such, the product related EMC requirements directly apply to the (main) PWB containing semiconductors. To meet economic constraints, EMC solutions need to be taken, as far as possible, within the semiconductors, such that the needs for external measures diminish. In order to select between the various applications suggested by different vendors, an EMC qualification is required too. Generally, the designer will face problems with CAD tools for PWB and semiconductor lay-out. The main problem is that all routers known are random routers which can do their functional job quite well on a bi- or multi-layer PWB, or with single or double metal processes. It will therefore be such that if the PWB or semiconductor is routed several times, using the same input, the results can be totally different. EMC results are commonly bad, mainly because the router is not told which lines need priority and which need to be close together. An additional problem to face is that both product and semiconductor developments need to go faster, by using all available tools. By adding as few as possible external (passive) components and considering geometrical constraints given by the automatic assembly tools we hope that it complies with the often stringent <u>mandatory</u> EMC requirements. The above given problems ask for an EMC evaluation method, by which the designer can, at any stage of the design, determine the degree of satisfying the EMC requirements. This EMC evaluation technique must be easy to use, easy to handle and not too expensive to assure usage of this method. The concept is based on the technical information now available in draft IEC 801-6. This concept will be explained in chapter 2. EIE/AN91001 #### 2 TEST METHOD ### 2.1 EMC regulations and standards With respect to EMC-standards we can concentrate ourselves best to the generic emission and immunity requirements given in European Standards EN 50081-1 and EN 50082-1 which become legally enforceable from 1992 onwards, especially to the European Market. In these standards reference is made to either IEC documents or CENELEC standards in which certain disturbance or emission phenomena are depicted. For most product groups, the IEC CISPR 11/22 documents or CENELEC European Norm 55011/22, class B apply for RF-emission, whereas for immunity phenomena IEC 801-2 through -6 or CENELEC 55024-x apply. In our particular case, considering IC-development and IC-application, the most important document is draft IEC 801-6 as it can be applied both to immunity <u>and emission</u>. The validity is given by the fact that the EM-radiation properties of cables and wires connected to the Device or Equipment Under Test (DUT or EUT) are substituted by simple passive networks. As passive networks have reciprocity both emission and immunity can be evaluated in the same set-up. ### 2.2 Basic Concept With the method, according to draft IEC 801-6, immunity to **conducted** RF-disturbances is tested. The set-up simulates the EM radiation effects by coupling the induced disturbing signals through Coupling/Decoupling Networks (CDNs) via the cables and wires to the PWB under test in a defined way, Fig.1. This method is applicable in the frequency range 150 kHz up to 230 (1000) MHz. The set-up with CDNs simulates "passive" cables which are, from the radiation point of view, at resonant length. The dimension of the PWB(s) between these cables and wires is assumed to be short compared to wavelengths involved. According to the existing radiation measurement procedures, either the cable contributions are eliminated by adding ferrites on them to serve reproducibility (EN 55020) or the cables shall be adjusted in length and geometry with each frequency to obtain maximum radiation (EN 55011/22). With the conducted "interaction" method, which simulates radiated RF-field phenomena, both problems are solved. Note 1: This method also reproduces the electric and magnetic near-fields to the PWB, associated with the source of disturbance (E and H in figure 2). Note 2: The method of publication 801-6 does not provide the injection (or measurement) of the current from an ideal current or voltage source. It rather provides the coupling of the disturbance signal from a real source, having a "radiation" resistance of 150 $\Omega$ , i.e. short-circuit current as well as open voltage are limited. CDNs are mainly defined by the common-mode impedance represented at the EUT-port side, which needs to be about 150 $\Omega$ to reference ( $\pm$ 20 $\Omega$ , freq. $\leq$ 30 Mhz, $\pm$ 60/-45 $\Omega$ , freq. $\geq$ 30 Mhz). Every CDN fulfilling the impedance requirements given in draft IEC 801-6 can be used. Typical application examples are given in the figures 3a) for shielded and 3b) for unshielded cables. In figure 3c) a simplified drawing for mechanical construction is given. By using new NiZn ferrite ( $\mu$ $\geq$ 1000), the entire frequency range can be covered by using one toroid on which we have 17 windings, $L_{(150 \text{ kHz})} \geq$ 280 $\mu$ H, and one bead-on-cable only. Fig.1. Schematic set-up for immunity test to RF conducted disturbances. Z<sub>ce</sub>: Common-mode EUT-point impedance of the coupling and decoupling network system, $Z_{ce} = 150 \Omega$ . Note: The $100~\Omega$ resistors are given by the coupling and decoupling networks. The left input is terminated by a (passive) 50 $\Omega$ load and the right input is loaded by the test generator. U. Test generator output voltage Ucm: Common-mode voltage between EUT and reference plane I Common-mode current through the EUT J<sub>com</sub>: Common-mode current density in the EUT E, H: Electric and magnetic fields Fig. 2. Equivalent circuit of Fig. 1 to explain the electromagnetic near-fields approximated by common-mode currents and voltages induced by a RF-source according to the immunity method to conducted disturbances. December 1991 669 **EIE/AN91001** Fig.3a. Coupling to shielded cables Fig.3b. Coupling to un-shielded (multi-wire) cables. Fig.3c. Mechanical drawing for the Coupling/Decoupling Network (CDN). #### 2.3 Test set-up for individual PWB units According to draft IEC 801-6, the PWB is placed on an insulating support, 0,1 metre above an earth reference plane. If the PWB will be used in a cabinet were a metal part is more near to the PWB than 0,1 metre, e.g. an adjacent PWB or a metal floor plate, then that shorter distance must be used. The earth reference plane shall exceed the projected geometry of the PWB and the used CDNs on all sides by at least 0,2 m. On all cables measures to obtain high common-mode impedances at the frequencies of interest or CDNs must be inserted. The number of CDNs should be limited (between 3 and 5) by restricting oneself to the representative functions and main (disturbing) current distributions occurring to the application in practice. The CDNs need to be placed directly on the earth reference plane, making proper contact to it, at a maximum distance of 0,3 metre from the PWB. The cables between the CDNs and the PWB shall be as short as possible. Their height over the earth reference plane must be kept between 30 and 50 mm (as long as possible). All auxiliary equipment, AE, required for the defined operation of the PWB, according to the specifications of the product, must be connected through high common-mode impedances or through CDNs to the PWB, e.g. communication, modem, printer, sensor, etc. This shall also be Philips Semiconductors Application note # Workbench EMC evaluation method EIE/AN91001 done for all auxiliary equipment necessary for ensuring proper data transfer and assessment of the functions. Warning 1: As measures to obtain high common-mode impedances <u>and</u> CDNs are transparent for functional signals, part of the disturbance signal may enter the auxiliary equipment in this way. As such, filtering measures will be inevitable. ### 2.4 Workbench Faraday cage The present proposal, suitable for small application boards and semiconductor evaluation, is a table-top size Faraday cage where all the connections to DC-supply and other auxiliary equipment are made through filters mounted on the wall of the Faraday cage. The wires and cables from these filters to the PWB need to be wrapped on a ferrite toroid, Philips NiZn material 4A15, to create a high common-mode impedance towards the walls of the Faraday cage (= earth reference plane), similar to the construction given in Fig.3c. Then, by means of resistors defined impedances, 150 $\Omega$ (100 $\Omega$ in series with an external 50 $\Omega$ coaxial load), are applied to simulate the radiation or reception performance of the cables or wires which might be connected to this application board in practical (product) application. Note 3: When a workbench Faraday cage is used, the earth reference plane is extended all around the PWB under test. As a result of the dimensions of the workbench Faraday cage, distance between PWB and CDN will remain $\leq 0.3$ metre. To keep this method simple, the maximum number of common-mode measurement points is set to 3. All other wires and cables must be provided with a RF-blocking (high common-mode impedance) device towards the feed-through panel on the wall of the Faraday cage. The common-mode measurement points on the PWB selected for evaluation are: - at the DC-power supply connector, - at the input port connector and - at the output port connector. Dependent on the implementation of the application board, containing one or several ICs, the emission or immunity performance can be measured, Fig.6 and 7. In those set-ups the coaxial 50 $\Omega$ loads outside the Faraday cage shall be exchanged in turn with either the selective voltmeter (spectrum analyzer) or the disturbance source. For worst-case testing the three connector positions, which are selected as common-mode points, are distributed all alongside the PWB, Fig.4a. This arrangement is chosen because one can not predict the geometrical lay-out the customer is going to use in his product. Note 4: Only if an application is required (to fulfil the requirements) such that all connectors are placed on one side only, Fig.4b. it must be tested as such. As a result, this condition then, shall be clearly stated in the application report. The determination of the common-mode points of the selected ports is based on the cables or wire-geometries likely to occur in product application. Furthermore, dependent on the product application, the appropriate CDN shall be selected. Philips Semiconductors Application note # Workbench EMC evaluation method EIE/AN91001 - When shielded cables are used, the shielding is referred to as common-mode point of that port (towards the wall of the Faraday cage), no matter how many wires are within that shielding. When unshielded cables are used, the common-mode impedance shall be established by placing a number of resistors to each individual wire such that the total common-mode resistance equals $100~\Omega$ (+ $50~\Omega$ external) towards the reference, being the wall of the Faraday cage. In series with those resistors capacitors ( $C_{total} \ge 20~nF$ ) must be applied such that the impedance requirements are still met. In product applications where an IC is fed by a signal source properly defined, i.e. signal and ground return are adjacent tracks, separation < 1 mm, <u>and</u> the tracks are short, length $\le$ 0,1 metre, a coaxial CDN-type can be applied. The same applies for the output configuration. Commonly, supply traces are not kept adjacent properly from IC to supply and therefore an unbalanced two-wire CDN should be used. If an IC is properly decoupled, supply and ground will be RF-short-circuited and a coaxial CDN can be applied. Warning 2: With analog circuits, outputs often cannot handle high capacitive loading which is represented by CDNs and its cables. As only the demodulated component at 1 kHz is of interest, an RC-filter need to be used in-between output and CDN, see Fig.5. Fig.4. Typical arrangements of inputs, outputs and supply alongside the IC. Fig.5. Filter/impedance matching network necessary to lower capacitive loading at IC outputs. Fig.6. Simplified set-up for immunity testing of the PWB using the workbench Faraday cage. December 1991 673 Fig.7. Simplified set-up for emission testing of the PWB using the workbench Faraday cage. # 2.5 Test equipment verification The verification of the disturbance signal used with immunity testing shall be done as follows: - 1. The RF generator is set at 10 MHz un-modulated. The output level shall be adjusted such that an rms voltage of e.g. 3 Volts appears at the port which will be connected to the coaxial feed-throughs (with the $100~\Omega$ series resistor behind) of the Faraday cage. This voltage is measured across the output of the $50~\Omega$ impedance matching network using a high input impedance RF-voltmeter. - Amplitude modulation must be turned on, using a 1 kHz sinewave (987.5 Hz / 1005 Hz, see chapter 3) and the modulation depth must be set to 80 %. By means of an oscilloscope this AM-signal shall be observed, Neither clipping nor modulation inversion may occur on the signal wave shape. In this case the peak-to-peak level will be 15,3 Volt. - 3 Volt rms = 4,24 Volt peak = 8,48 Volt peak-to-peak un-modulated. - 3 Volt 80 % modulated then becomes 15,27 Volt<sub>p-p</sub>. - 3. When this verification is accomplished this signal is provided to the coaxial feed-through connected to the common-mode point under test. With respect to emission measurements and the verification of the receiver used, further reference is made to IEC CISPR publication 16. If the emission limit is given in Quasi-Peak or Average limits the emission performance shall be measured in Peak-mode first (because it is fastest to apply). - 1. If the PWB satisfies the Average requirements, using the Peak-mode, no further measurements have to be carried out. - 2. When the PWB <u>does not</u> satisfy the Average requirements but complies with the Quasi-Peak requirements, additional measurements in Average mode need to be carried out. - 3. When the PWB <u>does not</u> fulfil either of the requirements, both measurements; Quasi-Peak and Average have to be carried out. Normally, there will be insufficient margin and PWB modifications will be necessary. Note 5: If the RF-signal is a continuous sinusoidal wave, then the indications from either Peak, Quasi-Peak and Average-mode detectors will be equal. ### 2.6 Requirements With conducted immunity measurements, the limit applicable to the product, e.g. draft IEC 801-6, can be used directly for verifying the IC application. When radiated immunity requirements are given, a transformation from electric fieldstrength requirements to induced voltages and currents has to be considered. For indication the following relation can be considered: EIE/AN91001 - 1 $Volt_{emf}$ (150 $\Omega$ in series) shall be taken for 1 Volt/metre (travelling wave, far field condition, generated by a tuned dipole antenna, distance $\geq 3$ metre) in case the cables and EUT are exposed to the EM-field, i.e. transformation ratio = 0 dB. - 0,3 Volt<sub>emf</sub> (150 $\Omega$ in series) shall be taken for 1 Volt/metre (travelling wave, far field condition, generated by parallel plate or strip-line set-ups) in case only the EUT is exposed to the EM-field and cables are excluded, i.e. transformation ratio = -10 dB. Note 6: The transformation ratio will depend on product size, the way cables are routed and frequency. When carrying out conducted emission measurements in the frequency range, freq. $\geq$ 30 Mhz, where the radiation limits are given in µVolt/metre, measured at 10 metre distance, the following approximation can be applied: = 30 dB $\mu$ V/m (= 30 $\mu$ V/m) at 10 metre distance from the object. E = $$(7/d)$$ . $\sqrt{(P_t)}$ , $P_t = U^2/150$ Ω, $$P_{\rm c} = U^2/150 \ \Omega_{\rm c}$$ E = $$(7/10).\sqrt{(U^2/150)}$$ = $U/17.5$ $$E(dB\mu V/m) = U(dB\mu V) - 25 dB.$$ In some emission standards, e.g. automotive and information technology equipment, conducted emission requirements are given over a large frequency range. Those requirements shall be adhered without any transformation. In portable applications such as radio or television where an on-top antenna is used, functional requirements will be much more severe than the legal requirements. Those functional limits need to be measured on the product, without any annoying disturbances, and thereafter the relation given in chapter 2.6 can be applied to the found limit. # EIE/AN91001 #### 3 EXAMPLES. All applications, e.g. a single op-amp, a transmission/speech circuit for telephone, $\mu P$ or video processor are tested on immunity with impedances (symmetrical and a-symmetrical loading) at inputs and outputs applied according to the application instructions (which shall be stated in the application report !!). When these (input, output) impedances are passive, they can be either outside or inside the workbench Faraday cage. When these are active, they should be outside. When coaxial feed-throughs are used, care must be taken by additional measures (low-pass-filters, see Fig.5) that the RF-energy which will be superimposed on either input or output lines does not adversely affect the performance of the auxiliary equipment <u>and</u> that by measures the source or load impedance remains properly defined (even at RF). The signal wires going from the application board to the feed-through connectors or filters shall be provided with an RF-blocking impedance, represented by 14 - 17 turns on a 4C65 (freq $\geq 1$ MHz) or better 4A15 ferrite toroid. By means of three 100 $\Omega$ resistors (PR 37 or PR 52, or equivalent power metal film resistors), the common of the input, output and supply is then coupled to the three coaxial feed-through connectors as indicated in paragraph 2.3. Externally, these connections are either coupled to the RF-disturbance generator, the selective voltmeter or terminated by a 50 $\Omega$ coaxial resistor. Note 7: The lay-out of the PWB shall be made such that either the typical performance of the circuit is tested (non-optimized mono- or bi-layer) or on e.g. multi-layer with every precaution taken to have optimal EMC performance of the IC in this application. Note 8: If the latter application cannot satisfy the EMC requirements, then no designer/customer will be capable of making a proper product with it at reasonable costs. ## 3.1 Audio applications. #### 3.1.1 Immunity The audio circuit shall be set at nominal (gain) conditions. When necessary or obtainable, a 1 kHz generator can be used to make the required setting. The baseband 1 kHz output signal across the normal load shall be measured. This level will be taken as a reference for the immunity performance testing. The disturbance signal (RF, 80 % modulated by 1 kHz) shall be applied to one of the commonports of the PWB under test in turn, while the other ports are terminated to reference by 50 $\Omega$ . A demodulated signal level (1 kHz only) of 40 dB less than the nominal signal level across that load is acceptable for proper operation. This level can be measured either by a low frequency spectrum analyzer or a sensitive AC-Voltmeter with a 1 kHz band-pass in front (as described in EN 55020). A typical pass-band bandwidth of 500 Hz is sufficient for these kind of measurements. EIE/AN91001 Example: The nominal level on the a,b-lines of a telephone system is 100 mV (across $600 \Omega$ ). The signal level across the earpiece can be measured and may be 30 mV (example only !!, determined by dynamic sensitivity of the earpiece). The level of the demodulated signal across that same earpiece, with the disturbance signal applied to the PWB shall be less than 0.3 mV. #### 3.1.2 Emission In most cases the emission from linear applications is nil unless it contains some oscillator. In the latter case, the disturbance generator shall be replaced by a spectrum analyzer covering the frequency range of interest, commonly 9 kHz to 1 GHz. As the emission will be continuous (at the fundamental and its harmonics), the detector chosen in the spectrum analyzer will not influence the readings. Where possible, the bandwidth requirements as stated in IEC CISPR publication 16 shall be adhered. # 3.2 Video applications ### 3.2.1 Immunity With video applications it will be such that most applications are based on an interlaced video frame sequence of 25 or 30 Hz. In both situations the spectrum around 1 kHz is fully crowded by harmonics of the frame frequency. It is therefore, that the modulation frequency, nominal 1 kHz should be shifted a little up/down such that it becomes an inter-harmonic of the frame frequency. Examples: 25 Hz $\rightarrow$ 987,5 Hz $30 \text{ Hz} \rightarrow 1005 \text{ Hz}$ To obtain nominal settings of the video application a colour bar signal is applied to the circuit to be fully operational. The demodulated signal at the outputs, e.g. CVBS, RGB or sync. can be measured by using a spectrum analyzer with a resolution bandwidth of $\leq 6$ Hz. This selectivity is required to obtain a signal-to-noise ratio sufficient to discriminate the demodulated signal from the wanted signal. Here the demodulated signal to nominal signal level<sub>(peak-to-peak)</sub> ratio has to be about -55 to -60 dB to be just not perceptible on the screen. This limit level can be found by superimposing a 1 kHz signal to the normal signal while observing the picture. The 1 kHz generator level is increased up to a level where it becomes just perceptible on the screen. This level referred to the functional signal is then taken as limit for the signal-to-interference ratio (S/I). Note 9: Special care shall be taken to assure that the demodulation of the spectrum analyzer is much less than the limit level to be measured. Additional low-pass filters, see Fig.5. may be required!! Furthermore, it may be necessary to use a comb-filter to lower the level of the frame harmonics. Example: The video signal level of the G-signal from the processor board to the video output stage is $3600 \text{ mV}_{p-p}$ . Then the demodulated signal shall be less than $3.6 \text{ mV}_{(peak)}$ . Note 10: Disturbing signals may also effect synchronization and as such appear as vertical zig-zag lines on the screen. This effect can only be measured by using a jitter or phase modulation meter between sync-out of the pattern generator and the output signal coming from the PWB. EIE/AN91001 #### 3.2.2 Emission As indicated above emission from the PWB is measured by replacing the disturbance generator by a spectrum analyzer or selective voltmeter. In analog applications, emission will be caused by the video signal itself and some oscillator signals used for demodulation, mixing, etc. According to the emission standard EN 55013, the test page pattern of teletext shall be used as video information. Where possible, the bandwidth and detector requirements as stated in IEC CISPR publication 16 shall be adhered. ### 3.3 Digital applications # 3.3.1 Immunity With digital applications, the main problem will be the fact that it needs wide address and data buses for operation. As these wide buses are inconvinient for this method, these shall be limited by simplifying the circuit or by introducing parallel-to-series and series-to-parallel decoders. Preferable, these decoders must be used on the PWB under test such that only one serial line will be fed through the wall of the cage. To isolate the decoders from the IC under test, series resistors, e.g. $1 \text{ k}\Omega$ , shall be used in-between the decoders and the IC. The common-mode points on the PWB needs to be chosen close to the IC to be tested instead of the serial decoder input and output ports indicated in chapter 2.4. By means of a tap, the signals at the output of the IC shall be monitored by means of an oscilloscope or a logic analyzer with an analog input and adjustable threshold levels. As criteria, the output signal of the IC may not exceed the specified high/low levels other than during functional transitions. When testing the inputs, the worst case DC-levels shall be superimposed to the input signal (if it does not already contain a DC-component from a previous stage). When the disturbance signal is applied to the common-mode points chosen, the signal levels at the outputs shall be observed. With more complex circuits it can be such that analog <u>and</u> digital inputs and outputs are available. By closing the loop; data $\rightarrow$ dig.out $\rightarrow$ dig.in $\rightarrow$ analog out $\rightarrow$ analog in $\rightarrow$ compare with initial data and turn on/off a flag, which drives a LED, a powerful test program is carried out. #### 3.3.2 Emission For proper operation, the normal program or coding shall be applied to the IC such that the emission measured is representative for a typical application. In case of a $\mu P$ , the outputs can be driven such that a digital ramp function (bit 0 = frequeny F0, bit 1 = F0/2, etc) is generated over its 4, 8 or 16 bits wide data bus. All buses will have typical length e.g. 0,1 metre. The end of the bus shall be terminated as indicated in the application report e.g. by 50 pF//3.3 k $\Omega$ . The commonmode points for the IC under test shall be taken (similar as with immunity) to measure the emission performance of the IC in its application. December 1991 679 EIE/AN91001 ### 4 THE WORKBENCH CAGE PARAMETERS The size of the workbench Faraday cage is chosen in such a way that it can contain most typical application and evaluation boards: Length: 500 mm Width: 350 mm Height: 150 mm The Workbench Faraday cage is made from carbon-free iron 1,5 mm thick. A conductive gasket is used between the box and the cover to make proper contact. The inside of the box is covered with an anti-static insulating material. The connections through the wall can be made by: Coax : $5 \times BNC$ , Single line : $4 \times \pi$ -filter, $(2 \times 1.35 \text{ nF} + 8 \mu\text{H}, 2 \text{ Amp.}, 50 \text{ Volt max.})$ 6 x Feed-through capacitors, (62 nF, 16 Amp., 500 Volt max.). The shielding effectiveness in $H_{x,y,z}$ directions is better than 60 dB in the frequency range 1 to 1000 MHz, measured with two 60 mm electrically shielded loops according to Mil.Std. 220. An example of the shielding effectiveness of the workbench Faraday cage is given in Fig.7. The characteristics of the $\pi$ -filters (Low-Pass-Filter at 1 MHz) and the feed-through capacitors are given in Fig.8. The choice for these filters is made such that by additional external measures the filtering performance can be enhanced at low frequencies. For most applications the given performance will be sufficient. These $\pi$ -filters can also be used at the outputs of digital circuits when using a 100 $\Omega$ resistor in series. In this case, the pass-band is limited to about 500 kHz, which is still sufficient to allow e.g. $1^2$ C-communication. Fig.7. Shielding effectiveness of the workbench Faraday cage. Fig. 8a. Performance of the $\pi$ -feed-through filter used with the workbench Faraday cage. Fig.8b. Filter performance of the feed-through capacitor used with the workbench Faraday cage. EIE/AN91001 ### 5 REFERENCES - [1] Draft IEC 801-6, Immunity to conducted disturbances, induced by radio frequency fields above 9 kHz, IEC 65A(secr), nov. 1991. - [2] 65A/77B(secretariat)121/88, Immunity to radiated radio-frequency electromagnetic fields, Draft publication IEC 901-3 2nd edition, 1991. - [3] IEC CISPR publication 20 2nd edition, Limits and methods of measurement of immunity characteristics of sound and television broadcast receivers and associated equipment, 1990. - [4] An evaluation method to characterize the EMC performance of PCBs containing ICs, M.J.Coenen, ESG 8801, Philips Components, 1988. - [5] ElectroMagnetic Compatibility (EMC) and Printed Circuit Board (PCB) constraints, M.J.Coenen, ESG 89001, Philips Components, 1989. - [6] Radiated emissions from common-mode currents, C.R.Paul, IEEE EMC Symposium on EMC, Zürich, 1987. - [7] Antenna theory, analysis and design, C.A.Balanis, Harper and Row Publishers, New York, 1982. - [8] Electromagnetic theory, J.A.Stratton, McGraw Hill, New York and London, 1941. - [9] Taschenbuch der Hochfrequenztechnik, H.Meinke, F.W.Gundlach, Springer Verlag, Berlin und New York. 1968. Remark: Welded joints and finished 683 Annex 1. Drawing of the workbench Faraday cage. **EIE/AN91006** Author: Th. v. Daele, Product Concept & Application Laboratory, Eindhoven, The Netherlands #### 1. INTRODUCTION With an 83CL410 microcontroller and a PCF1252-x reset circuit, it is possible to make a software driven A-to-D converter. In this application note, an example is described where an 83CL410 measures its own supply voltage. The resolution of the measurement is 0.1V. The program example also refers to this application. Chapter 2 describes the algorithm of the conversion. In chapter 3 the example with 83CL410/PCF1252 is described. Both hardware and software of this example are explained. #### References: - 80C51-based 8-bit microcontrollers; Data Handbook IC20 - PCF1252-x data sheet #### 2. A-TO-D CONVERSION PRINCIPLE The basic principle of the conversion is to convert the voltage to a time measurement. A microcontroller without an on-chip A-to-D converter cannot measure voltages directly, but if converted to a time measurement, this can be done by software or with the help of an on-chip timer/count. Figure 1 shows the basic circuit to do the conversion. The circuit consists of an integrator circuit, a voltage reference and an analog input switch S. The analog input switch is controlled by the microcontroller. The integrator is built around a comparator whose output is connected to a microcontroller input. Before the measurement is started, the analog switch connects the integrator input to ground, so that the integration capacitor is fully discharged. The measurement is started by connecting the integrator input to the unknown voltage. The integration capacitor will charge up. When the non-inverting input exceeds the reference voltage, the comparator output will switch from LOW to HIGH. EIE/AN91006 The time between starting the measurement and the moment that the comparator output becomes HIGH, is measured by the microcontroller and is: $$T_1 = -RC.ln \frac{V_x - V_{ref}}{V_x}$$ The charging continues until the capacitor is fully charged. Then the integrator input is grounded via the analog switch. The integration capacitor discharges while the comparator output is HIGH. When the input voltage becomes lower than the reference voltage, the comparator output becomes LOW again. The time between the start of the discharging and the moment that the comparator output becomes LOW, is measured by the microcontroller and is: $$T_2 = -RC.In \frac{V_{ref}}{V_x}$$ When the microcontroller uses the ratio between $T_1$ and $T_2$ , the result becomes independent of the values R and C. The resulting ratio can then be used as a pointer to a look-up table that may contain an indication for the measured parameter or display data. #### 3. EXAMPLE OF CONVERSION PRINCIPLE #### 3.1 Hardware In the example, an application is used where a microcontroller measures its own supply voltage. The supply voltage is generated by solar cells, so power consumption should be minimized. The measured voltage is shown on an LCD display. An 83CL410 is used as microcontroller. This controller is an 80C51 family member. Compared with a standard 80C51, it has the following extra features: - Wide supply voltage range of 1.8V to 6V. - Wide operating frequency range of 32kHz to 20MHz with internal oscillator. With external oscillator there are no limitations on the lower frequency limit. - Byte I2C interface instead of UART. - 8 extra external interrupt inputs on P1. The interrupt level is programmable. These interrupts can terminate the power-down mode. - 3 mask programmable I/O port configurations. These configurations are: - Standard quasi-bidirectional I/O - Open-drain output, standard input - Push-pull output, no input - I/O port levels after RESET are mask programmable. Of these features, only the byte I2C interface is not used. The PCF1252 is used for monitoring the power supply voltage and generating a reset pulse when the supply drops too much. Several versions of PCF1252 are available, every one with its own trip voltage. The PCF1252 also has an unused comparator. This comparator is used for the integrator circuit. The inverting input is internally connected to a 1.3V reference. Figure 2 shows the A-to-D conversion part of the circuit. # EIE/AN91006 R1 and C1 determine the time-constant of the circuit. The input of the integrator is connected to P1.1 of the microcontroller. This port line has a push-pull configuration. It is used as the analog switch shown in Figure 1. When this output line is made HIGH, the integrator is connected to the supply voltage. This is the voltage to be measured. The voltages on the non-inverting input and the output are shown in Figure 2. The output of the comparator is LOW, and the capacitor will be charged. When the voltage at the non-inverting input becomes higher than 1.3V, the comparator output will become HIGH. This HIGH level will cause an interrupt on P1.0 (IL2=1). The voltage on the inverting input will want to rise to $V_{\rm CC}$ + 1.3V. this voltage is limited by 2 external diodes. R2 is a current limit resistor. Next step is that P1.1 becomes LOW, so that the capacitor will be discharged. The P1.0 input is now programmed to generate an interrupt on a LOW level (IL2=0). This will happen when the voltage on the inverting input has dropped below 1.3V. At this point, both charge and discharge times are known, and the supply voltage can be calculated. In this circuit, the PCF1252-9 is used, which will generate a reset pulse when the supply voltage is lower than 2.55V. This limits the lower end of the supply voltage range. However, the 83CL410 is able to go as low as 1.8V. To minimize power consumption, the lowest frequency is used where the internal oscillator can still be sued. this is 32.768kHz. This parameter, together with the resolution that must be met, determine the minimum value of R1.C1. In this example, a resolution of 0.1V is achieved. The software is made to handle voltage measurements from 1.8V to 5V. **EIE/AN91006** To determine the minimum value of R1C1, the measurement of 5.0V and 4.95V is important because here the distance between measurements of $T_1$ and $T_2$ is minimal. $$\begin{array}{lll} V_{x}=5.0V; & T_{1}=0.301RC \\ T_{2}=1.347RC \\ T_{2}/T_{1}=4.437 \\ \end{array} \\ V_{x}=4.95V; & T_{1}=0.304RC \\ T_{2}=1.337RC \\ T_{2}/T_{1}=4.398 \\ V_{x}=4.9V; & T_{1}=0.308RC \\ T_{2}=1.327RC \\ T_{2}/T_{1}=4.308 \\ \end{array}$$ Because of latency in the interrupt routine, a deviation $\Delta t$ may occur in $T_1$ and $T_2$ . The following conditions must be met: $$\begin{array}{ll} V_{X} = 5.0V; & \frac{T_{2}}{T_{1}} & \frac{1.347RC \pm \Delta t}{0.301RC \pm \Delta t} \geq 4.398 \\ \\ V_{X} = 4.9V; & \frac{T_{2}}{T_{1}} & \frac{1.327RC \pm \Delta t}{0.308RC \pm \Delta t} \geq 4.398 \end{array}$$ In this example, there is an uncertainty of 2 machine cycles when measuring $T_1$ and $T_2$ . Given an XTAL frequency of 32.768kHz, the minimum value of RC is 0.172. The complete circuit diagram is shown of the example with the LCD connections. Since the LCD connections are only outputs, the push-pull configuration is used for this. # **EIE/AN91006** EIE/AN91006 #### 3.2 Software In chapter 4 the listing of the program is shown. After RESET the initialization takes place from L.45 to L.70. The following timers 83CL410 are used: Timer\_0: Used to measure the T1 and T2 (mode\_1). Timer\_1: Used to generate a timer interrupt for LCD polarity reverse (mode\_2). This is the auto-reload mode. Every 10ms an interrupt is generated. 3 interrupts are used: INT2: External interrupt for the A-to-D conversion. Priority level-1. INT4: Interrupt from PCD1252-9 when supply voltage is smaller than 2.55V. Priority level\_1. Timer\_1: Interrupt for LCD polarity reverse. Priority level\_0. The measurement is started at L74. The interrupt level of INT2 is set to '1' and time\_0 is started to measure T1. P1.1 is set, so that the supply-voltage is connected to the integrator input. While the integration capacitor is charging, the 83CL410 is in IDLE-mode to reduce power consumption. This part of the measurement is identified by ADC\_Status=1. When INT2 is generated, the interrupt routine is entered (from L.181). Timer\_0 is read and its value is stored in R4 (MSB) and R5 (LSB). The interrupt level of INT2 is cleared to '0' for the second part of the measurement. After clearing the interrupt flag, the main program is entered again at L.85. a delay is entered at this point so that the integration capacitor can be discharged sufficiently from $V_x + 1.3V$ to $V_x$ . The delay is 32 time-outs of timer\_1. During this delay, the controller is in IDLE mode. After the delay, P1.0 is cleared to discharge the integration capacitor. Timer\_0 is started to measure T2. Again the microcontroller enters the IDLE mode until INT2 is generated. In the interrupt routine, the interrupt level is now set to '1' again for the next A-to-D conversion. In the main program, T2 is copied to R6 (MSB) and R7 (LSB) (L.96 and L97). Now that T1 and T2 are known, the measured voltage can be determined. This is done by calculating the ratio between T1 and T2, and converting this to a pointer which points to a table with the segment data of the LCD display. In the calculation, the ratio between T1 and T2 should be equal or greater than 1. If T2<T1 (L.107) then the flag 'gr\_2V6' will be cleared (L1.65) and [R4.R5] and [R6.R7] are exchanged. This point is met when the input voltage is 2.55V. Normally, voltages < 2.55V will not be measured, because by then the PCF1252-9 has generated an interrupt on INT4. This means a power-failure and the only way to start the measurement again, is that the PCF1252-9 resets the microcontroller. The INT4 routine is from L.227 .. L.237). The program, however, contains the conversion table for input voltages as low as 1.8V. The pointer to the table (stored in [R6.R7]) is calculated by: [R6.R7] = 16\*[R6.R7] / [R4.R5]. The division is done by the subroutine '\_sdivi'. This is a library function contained in the C-library of the BSO/Tasking C-compiler package (type number OM41326). This library must be linked to this program. Of the result, only R7 is relevant. The segment data contains 2 bytes, so pointer R7 is multiplied by 2 (L.134). There are 2 segment tables: one for voltages > 2.55V (L.247 .. L.274) and one for voltages < 2.55V (L.284 .. L.304). DPTR is used as pointer for this table and is calculated by adding the table base (L.129 .. L.132) and R7 (L.134 .. L.137). The following table shows the relation between the measured voltage, 16\*T1/T2 or 16\*T2/T1, the pointer and the segment data. # EIE/AN91006 | | | Input voltage > 2.55V | | | |---------------|----------|-----------------------|--------------|------------| | Input Voltage | 16*T2/T1 | Table addresses | Segment data | Display | | 4.95 | 70.4 | 140 147 | 0x6d,0xbf | 5.0V | | 4.85 | 67.5 | 136 139 | 0x66,0xef | 4.9V | | 4.75 | 64.83 | 130 135 | 0x66,0xff | 4.8V | | 4.65 | 62.18 | 124 129 | 0x66,0x87 | 4.7V | | 4.55 | 59.57 | 120 123 | 0x66,0xfd | 4.6V | | 4.45 | 56.98 | 114 119 | 0x66,0xed | 4.5V | | 4.35 | 54.43 | 108 113 | 0x66,0xeb | 4.4V | | 4.25 | 51.91 | 104 107 | 0x66,0xcf | 4.3V | | 4.15 | 49.42 | 98 103 | 0x66,0xdb | 4.2V | | 4.05 | 46.96 | 94 97 | 0x66,0x86 | 4.1V | | 3.95 | 44.54 | 90 93 | 0x66,0xbf | 4.0V | | 3.85 | 42.14 | 84 89 | 0x4f,0xef | 3.9V | | 3.75 | 39.82 | 80 83 | 0x4f,0xff | 3.8V | | 3.65 | 37.51 | 76 79 | 0x4f,0x87 | 3.7V | | 3.55 | 35.24 | 70 75 | 0x4f,0xfd | 3.6V | | 3.45 | 33.02 | 66 69 | 0x4f,0xed | 3.5V | | 3.35 | 30.83 | 62 65 | 0x4f,0xeb | 3.4V | | 3.25 | 28.7 | 58 61 | 0x4f,0xcf | 3.3V | | 3.15 | 26.6 | 54 57 | 0x4f,0xdb | 3.2V | | 3.05 | 24.56 | 48 53 | 0x4f,0x86 | 3.1V | | 2.95 | 22.56 | 46 47 | 0x4f,0xbf | 3.0V | | 2.85 | 20.62 | 42 45 | 0xdb,0xef | 2.9V LOBAT | | 2.75 | 18.73 | 38 41 | 0xdb,0xff | 2.8V LOBAT | | 2.65 | 16.89 | 34 37 | 0xdb,0x87 | 2.7V LOBAT | | 2.55 | 15.12 | 32 34 | 0xdb,0xfd | 2.6V LOBAT | # EIE/AN91006 | | | Input voltage < 2.55V | | | |---------------|----------|-----------------------|--------------|------------| | Input Voltage | 16*T1/T2 | Table addresses | Segment data | Display | | 2.55 | 16.92 | 32 37 | 0xdb,0xed | 2.5V LOBAT | | 2.45 | 19.09 | 38 43 | 0xdb,0xeb | 2.4V LOBAT | | 2.35 | 21.77 | 44 49 | 0xdb,0xcf | 2.3V LOBAT | | 2.25 | 25.15 | 50 57 | 0xdb,0xdb | 2.2V LOBAT | | 2.15 | 29.51 | 58 69 | 0xdb,0x86 | 2.1V LOBAT | | 2.05 | 25.32 | 70 85 | 0xdb,0xbf | 2.0V LOBAT | | 1.95 | 43.35 | 86 109 | 0x86,0xef | 1.9V LOBAT | | 1.85 | 54.96 | 110 119 | 0x86,0xff | 1.8V LOBAT | Now the data can be displayed on the LCD display. When writing data to the LCD, the timer\_1 interrupt is disabled. The value of output LCD\_COM (controlled by timer\_1 interrupt routine) determines whether the data must be written inverted to the LCD or not. The data is written non-inverted from L.147 .. L.150, inverted from L.153 .. L.158. When the data is written, timer\_1 interrupt is enabled again, and a new A-to-D conversion is started at label Start\_ADC. From L.210 .. L219 the timer\_1 interrupt routine is shown. In this routine the segment lines to the LCD display are inverted (on P2 and P3). Also LCD\_COM is inverted, which is the COMMON pin of the display. 691 On L218 the value Dis\_tim is incremented. This is for the delay between the measurement of T1 and T2 (see L.85). June 1991 4: SOFTWARE LISTING # A/D conversion with P83CL410 PCF1252-x # EIE/AN91006 ``` TSW-ASM51 V3.0b Serial #00052252 Main program PAGE 1 LOC OBJ LINE SOURCE 1 $TITLE (Main program) 2 $DEBUG # 1 "C:\Tools\Tasking\ASM51\Include\8051\Reg410.Inc" 6 ;Timer_0 is used for A/D conversion in combination with PCF1252 ;Timer_1 is used as time base for LCD switching ;INT2 is used as input for A/D conversion ;INT4 is used as power-failure input from PCF1252 ;All timing related to Xtal=32.768kHz 12 0091 13 Anal in EQU 91h ;P1.1 is voltage switch 0095 14 LCD COM EQU 95h ;P1.5 is COM of LCD display 00B0 15 Digit 1 0B0h EQU ;P3 is first digit of LCD ;display 00A0 16 Digit 2 EQU OAOh ;P2 is second digit of LCD ;display 17 18 19 20 21 Flags segment Bit 22 Stack segment Data 23 Main segment Code Inblock 24 Table 1 segment Code Page 25 Table_2 segment Code Page 26 ADC segment Code 27 LCD segment Code 28 Power_F segment Code 29 30 RSEG Flags 0000: ADC_Status: 31 DBIT 1 ;Status flag AD converter 0001: Gr 2v6: 32 DBIT 1 ;Flag indicating that V<2.55V 33 34 RSEG Stack 0000: 35 Stk St: DS 20 ;Define stack 36 REG END 37 Dis_tim set r2 ; Timer for cap. discharge from Vdd+1.3 ; to Vdd 38 39 ``` 692 June 1991 TSW-ASM51 V3.0b Serial #00052252 Main program # EIE/AN91006 ``` PAGE 2 LOC OBJ LINE SOURCE 40 CSEG AT 00 ;Reset vector 41 0000: 020000 42 1jmp Start 43 44 RSEG Main ;Ground analog input clr Anal in 0000: C291 45 Start: mov sp, #Stk_St-1 ; Initialise stack pointer 0002: 7581FF 46 clr ADC_Status ; Initialise ADC status 0005: C200 47 48 ; INT2 is priority level 1 (Analog mov ip1, #05h 0007: 75F805 49 ; measurem.) ; INT4 is priority level 1 (Power fail) 50 ;Timer 1 interrupt level 0 (LCD switch) 51 ;INT4 on low level 000A: 53E9FB anl ix1, #0fbh 000D: D2EA 5.3 setb ex4 :Enable INT4 setb ea ;Global enable interrupts 000F: D2AF 54 5.5 ; Timer 1 mode (LCD switch) 0011: 758921 mov tmod, #21h 56 8 bit auto reload mode 57 ; Timer 0 mode (A/D conversion) 58 16 bit timer ;Delay for discharging cap's (+/- 1sec) 0014: 758DF5 mov th1, #0f5h 60 mov tl1,#050h 0017: 758B50 61 setb trl 001A: D28E 62 001C: 308FFD 63 inb tf1,$ clr tf1 001F: C28F 64 0021: C28E 65 clr tr1 66 0023: 758BE1 mov tl1, #0e1h ;LCD switch rate: 10ms 67 mov th1, #0e1h 0026: 758DE1 68 ;Start timer_1 0029: D28E setb trl 69 ;Enable timer_1 interrupt 002B: D2AB 70 setb et1 71 ; Measurement of supply voltage 72 002D: 43E901 orl ix1, #01H ;INT2 on '1' input level 73 0030: 74 Start_ADC: mov th0, #OFFh ;Load timer 0 0030: 758CFF 75 0033: 758AFB 76 mov tl0, #0FBh 0036: D28C 77 setb tr0 ;Start timer 0 ;Start raising part of measurement 0038: D291 78 setb Anal in ;Enable INT2 setb ex2 003A: D2E8 79 ;Go to idle mode 003C: 438701 80 Id 1: orl pcon, #01 jnb ADC Status, Id 1; Wait till first part of measurement 003F: 3000FA 81. ; is handled ;Exit from idle mode could be from LCD 82 ;interrupt ``` # EIE/AN91006 | TSW-A | SM51 V3. | Ob s | erial | #00052252 Main | program | | |-------|---------------|------|-------|----------------|---------------------------------------|--------------------------------------------------------------------| | PAGE | 3 | | | | | | | LOC | ОВЈ | | LINE | SOURCE | | | | ьос | ОВО | | LINE | SOURCE | | | | 0042: | 7 <b>A</b> 00 | | 83 | | mov Die tim #0 | 0 ;Discharge delay: Vdd+1.3Vdd | | | 438701 | | 84 | Id 2: | orl pcon, #01 | ;Go to idle mode | | | BA20FA | | 85 | - <del></del> | · · · · · · · · · · · · · · · · · · · | 20h,Id_2 ;Delay: 32 LCD_time_outs | | | | | 86 | | 0,1.0 212_01, 0. | ;If not equal: idle | | | | | 87 | | | , ii not equal. Idle | | 004A: | 758CFF | | 88 | | mov th0, #0FFh | ;Load timer 0 | | 004D: | 758AFB | | 89 | | mov tl0,#0FBh | / Lodd Clinol_0 | | 0050: | D28C | | 90 | | setb tr0 | ;Start timer 0 | | 0052: | | | 91 | | clr Anal in | ;Start second part of measurement is | | | | | | | orr Amar_rm | ; handled | | | | | 92 | | | , nandled | | 0054: | 438701 | | 93 | Id 3: | orl pcon,#01 | ;Go to idle mode | | | 2000FA | R | 94 | 14_5. | = | | | 005A: | | • | 95 | | clr ex2 | <pre>Id_3 ;Wait till measurement is finished ;Disable INT2</pre> | | 005C: | | | 96 | | mov r6, th0 | | | | | | ,,, | | 110V 16, CHO | ;Get timer data of second part of | | 005E: | AFRA | | 97 | | mov r7,t10 | ;measurement<br>;T2 | | | | | 98 | | MOV 17, C10 | ;Process data | | | | | 99 | | | Flocess data | | | | | 100 | | | .Tf m1>m2 Abas (DC D71 and (DA DE) | | | | | 101 | | | ;If T1>T2 then [R6.R7] and [R4.R5] must | | | | | 102 | | | ;be exchanged. Also other segment table | | 0060: | D201 | R | 103 | | aath an 200 | ;must be used. | | 0062: | | | 103 | | setb gr_2v6<br>clr c | ;Set gr_2v6 flag | | 0063: | | | 105 | | | ;Test T2-T1 | | 0064: | | | 106 | | mov a, r6 | | | 0065: | | | 107 | | subb a, r4 | .0.6 | | 0067: | | | 108 | | jc Small_2v6 | ;<2.6V: clear flag, exchange registers | | 0069: | | | 109 | | jnz Calculate | | | 0069. | | | 110 | | mov a,r7 | | | 006B: | | | 111 | | subb a, r5 | | | 0066: | 4046 | | 112 | | jc Small_2v6 | er en | | | | | 113 | | | ;Calculate T2/T1 | | | | | 114 | | | ; [R6.R7] = [R6.R7] / [R4.R5] | | | | | 115 | | | ; 1 <result<4.4< td=""></result<4.4<> | | 006D: | 7006 | | 116 | Calculate: | | ;Before dividing: [R6.R7]=16*[R6.R7] | | 006F: | | | | Calculate: | mov r0,#06 | ;r0 points to r6 | | 0070: | | | 117 | | mov a,r7 | | | 0070: | | | 118 | | swap a | | | | | | 119 | | anl a,#0f0h | <u> </u> | | 0073: | | | 120 | | xch a,r7 | ;r7 shifted 4 bits left | | 0074: | | | 121 | | swap a | | | 0075: | | | 122 | | xch a,r6 | | | 0076: | | | 123 | | swap a | ; nibbles r6 swapped | | 0077: | | | 124 | | xchd a,@r0 | | | 0078: | FE | | 125 | | mov r6,a | ;r6 also shifted 4 bits to the left | | | | | 126 | | | | # EIE/AN91006 ``` TSW-ASM51 V3.0b Serial #00052252 Main program PAGE LOC OBJ LINE SOURCE 0079: 120000 127 lcall sdivi ; [R6.R7]=16*T2/T1 128 007c: 300105 129 jnb Gr 2v6, Sec tab 007F: 900000 R 130 mov dptr, #Seg tab 1 0082: 8003 131 simp Calc point 0084: 900000 R 132 Sec tab: mov dptr, #Seg tab 2 0087: C3 133 Calc_point: clr c 0088: EF 134 mov a, r7 ; Calculate address of segment info 0089: 33 135 ;2*R7 rlc a 008A: F582 136 mov dpl,a 008C: C3 137 clr c 008D: 9494 138 subb a, #148 ; If a>148 then V>5.0: Display H.I V 008F: 4003 139 jc Display 0091: 758294 140 mov dpl,#148 ; V>5.0V 141 0094: 142 Display: ;Display result. DPTR points to segment data 0094: C2AB 143 clr et1 ;Disable LCD switch interrupt 0096: E4 144 clr a 0097: 93 145 movc a, @a+dptr ;Get segment 1 data (digit + LOBAT) 0098: 209509 146 jb LCD_COM,Com_1 ; If LCD COM=1, then invert result 009B: F5B0 147 mov Digit 1,a 009D: 7401 148 mov a, #01 009F: 93 149 movc a,@a+dptr ;Get segment_2 data (digit + point) 00A0: F5A0 150 mov Digit 2,a 00A2: 01AF R 151 ajmp New meas 0044 - 152 Com 1: 00A4: 64FF 153 xrl a, #0ffh 00A6: F5B0 154 mov Digit 1, a 00A8: 7401 155 mov a, #01 00AA: 93 156 movc a, @a+dptr ; Get segment 2 data (digit+point) 00AB: 64FF 157 xrl a, #0ffh 00AD: F5A0 158 mov Digit_2,a 00AF: 159 New meas: 00AF: D2AB 160 setb et1 ; Enable LCD switch interrupt 00B1: 0130 161 ajmp Start_ADC 162 163 00B3: 164 Small 2v6: ; V<2.55V. Exchange registers 00B3: C201 165 R clr Gr_2v6 ;Clear flag 00B5: CC 166 xch a,r4 ;Exchange [R4.R5] and [R6.R7] 00B6: CE 167 xch a,r6 00B7: FC 168 mov r4, a 00B8: CD 169 xch a,r5 00B9: CF 170 xch a, r7 OOBA: FD 171 mov r5, a 00BB: 80B0 172 sjmp Calculate ;Start calculation ``` # **EIE/AN91006** ``` TSW-ASM51 V3.0b Serial #00052252 Main program PAGE 5 LOC OBJ LINE SOURCE 173 174 extrn code ( sdivi) 175 $EJECT 176 177 178 ; A/D measurement interrupt routine (INT2) 179 180 181 CSEG AT 3Bh ; INT2 vector (Voltage measurement) 003B: 020000 R 182 ljmp ADC Int 183 184 RSEG ADC clr tr0 ;Stop timer 0 0000: C28C R 185 ADC Int: 0002: B200 R 186 cpl ADC Status 0004: 300009 R 187 jnb ADC Status, Stat_0 188 189 ; ADC_Status is '1' 0007: AC8C 190 mov r4, th0 ;Get timer_0 values mov r5,t10 0009: AD8A 191 ;T1 000B: 53E9FE 192 anl ix1, #OFEh ; INT2 on '0' input level 193 ;Check discharge Vd+1.3V 194 195 000E: 8003 196 sjmp Leave INT2 197 198 ; ADC_Status is '0' 0010: 43E901 199 Stat_0: orl ix1, #01H ;INT2 on '1' input level 200 0013: C2C0 201 Leave_INT2: clr iq2 ;Clear interrupt flag 0015: 32 202 reti 203 204 205 $eject 206 207 208 ;Timer_1 interrupt for inverting LCD signals 209 ************** 210 ;Timer_1 interrupt (LCD switch) 211 CSEG AT 1Bh ljmp LCD_int 001B: 020000 R 212 213 214 RSEG LCD xrl Digit 1,#0ffh ;Invert digit 1 0000: 63B0FF R 215 LCD int: cpl LCD COM ;Invert LCD_COM 0003: B295 216 0005: 63AOFF 217 xrl Digit_2,#0ffh ;Invert digit_2 ``` # **EIE/AN91006** ``` TSW-ASM51 V3.0b Serial #00052252 Main program PAGE 6 LOC OBJ LINE SOURCE inc Dis_tim ; Update discharge timer A0 :8000 218 0009: 32 219 reti 220 221 $eject 223 ;************************** 224 ;Power failure interrupt routine (INT4) 225 226 CSEG AT 04Bh ; Power failure interrupt from PCF1252 227 004B: 020000 R 228 ljmp P_Fail 229 230 RSEG Power_F 0000: C291 R 231 P_Fail: clr Anal_in ;Ground analog input 232 clr a 0002: E4 0003: F5B0 233 0005: C295 234 mov Digit_1,a ;Clear LCD clr LCD_COM 0005: C295 mov Digit_2,a 0007: F5A0 235 sjmp $ ;Exit only with RESET !! 236 0009: 80FE 237 238 $eject 239 240 ``` # EIE/AN91006 | TSW-ASM51 V3.0b Serial | #00052252 Main program | | |------------------------|---------------------------------------|---------------------------------| | PAGE 7 | | | | LOC OBJ LINE | SOURCE | | | 241 | ;Table with LCD segment data for V>=2 | .55v | | 242 | | | | 243 | | | | 244 | rseg table_1 | | | 245 | | | | 0000: R 246 | Seg_Tab_1: | | | 0000: 247 | ds 32 | ; V<2.55V. (Adr:031) | | 0020: DBFD 248 | db Odbh,Ofdh | ;'2.6V LOBAT' | | | | ; (Adr:3233) | | 0022: DB87DB87 249 | db 0dbh,87h,0dbh,87h | ;'2.7V LOBAT' | | | | ; (Adr:3437) | | 0026: DBFFDBFF 250 | db Odbh,Offh,Odbh,Off | h ;'2.8V LOBAT' | | | | ; (Adr: 3841) | | 002A: DBEFDBEF 251 | db Odbh, Oefh, Odbh, Oef | h ;'2.9V LOBAT' | | | | ; (Adr: 4245) | | 002E: 4FBF 252 | db 04fh,0bfh | ;'3.0V' (Adr:4647) | | 0030: 4F864F86 253 | db 04fh,86h,04fh,86h, | 04fh,86h ;'3.1V' (Adr:4853) | | 0034: 4F86 | | | | 0036: 4FDB4FDB 254 | db 4fh,0dbh,4fh,0dbh | ;'3.2V' (Adr:5457) | | 003A: 4FCF4FCF 255 | db 4fh,0cfh,4fh,0cfh | ;'3.3V' (Adr:5861) | | 003E: 4FE64FE6 256 | db 4fh,0e6h,4fh,0e6h | ;'3.4V' (Adr:6265) | | 0042: 4FED4FED 257 | db 4fh,0edh,4fh,0edh | ;'3.5V' (Adr:6669) | | 0046: 4FFD4FFD 258 | db 4fh,0fdh,4fh,0fdh, | 4fh,0fdh ;'3.6V' (Adr:7075) | | 004A: 4FFD | | | | 004C: 4F874F87 259 | db 4fh,87h,4fh,87h | ;'3.7V' (Adr:7679) | | 0050: 4FFF4FFF 260 | db 4fh,0ffh,4fh,0ffh | ;'3.8V' (Adr:8083) | | 0054: 4FEF4FEF 261 | db 4fh,0efh,4fh,0efh, | 4fh,0efh ;'3.9V' (Adr:8489) | | 0058: 4FEF | | | | 005A: 66BF66BF 262 | db 66h, 0bfh, 66h, 0bfh | ;'4.0V' (Adr:9093) | | 005E: 66866686 263 | db 66h,86h,66h,86h | ;'4.1V' (Adr:9497) | | 0062: 66DB66DB 264 | db 66h,0dbh,66h,0dbh, | 66h,0dbh ;'4.2V' (Adr:98103) | | 0066: 66DB | | | | 0068: 66CF66CF 26 | db 66h,0cfh,66h,0cfh | ;'4.3V' (Adr:104107) | | 006C: 66E666E6 26 | db 66h,0e6h,66h,0e6h, | 66h,0e6h ;'4.4V' (Adr:108113) | | 0070: 66E6 | | | | 0072: 66ED66ED 26 | db 66h,0edh,66h,0edh, | 66h, Oedh ;'4.5V' (Adr:114119) | | 0076: 66ED | | | | 0078: 66FD66FD 268 | | ;'4.6V' (Adr:120123) | | 007C: 66876687 269 | db 66h,87h,66h,87h,66 | Sh,87h ;'4.7V' (Adr:124129) | | 0080: 6687 | | | | 0082: 66FF66FF 270 | db 66h,0ffh,66h,0ffh, | 66h,0ffh ;'4.8V' (Adr:130135) | | 0086: 66FF | | | | 0088: 66EF66EF 27: | | ;'4.9V' (Adr:136139) | | 008C: 6DBF6DBF 27 | db 06dh,0bfh,06dh,0bf | h,06dh,0bfh;'5.0V' (Adr:140147) | | 0090: 6DBF | | | | 0092: 6DBF 27: | | | | 0094: 76B0 27 | | ;'H.IV' (Adr:148149) | | 27 | | | | 27 | 5 \$EJECT | | 698 June 1991 # EIE/AN91006 ``` TSW-ASM51 V3.0b Serial #00052252 Main program PAGE LOC OBJ LINE SOURCE 277 278 ; Table with LCD segment data for V<=2.55V 279 280 281 rseg table 2 282 283 0000: 284 Seg_Tab_2: ; V>2.55V. (Adr:0..31) 0000: 285 ds 32 db 0dbh, 0edh, 0dbh, 0edh, 0dbh, 0edh; '2.5V LOBAT' 286 0020: DBEDDBED ; (Adr: 32..37) 0024: DBED db 0dbh, 0e6h, 0dbh, 0e6h, 0dbh, 0e6h; '2.4V LOBAT' 0026: DBE6DBE6 287 ; (Adr: 38..43) 002A: DBE6 db Odbh, Ocfh, Odbh, Ocfh, Odbh, Ocfh; '2.3V LOBAT' 002C: DBCFDBCF 288 0030: DBCF db 0dbh, 0dbh, 0dbh, 0dbh, 0dbh; '2.2V LOBAT' 0032: DBDBDBDB 289 ; (Adr:50..57) 0036: DBDB db Odbh, Odbh 0038: DBDB 290 ; '2.1V LOBAT' db Odbh, 86h, Odbh, 86h, Odbh, 86h 003A: DB86DB86 291 ; (Adr:58..69) 003E: DB86 0040: DB86DB86 292 db 0dbh, 86h, 0dbh, 86h, 0dbh, 86h 0044: DB86 db Odbh, Obfh, Odbh, Obfh, Odbh, Obfh; '2.0V LOBAT' 0046: DBBFDBBF 293 ; (Adr: 70..85) 004A: DBBF db Odbh, Obfh, Odbh, Obfh, Odbh, Obfh 004C: DBBFDBBF 0050: DBBF db Odbh, Obfh, Odbh, Obfh 0052: DBBFDBBF 295 db 86h, 0efh, 86h, 0efh, 86h, 0efh ;'1.9V LOBAT' 0056: 86EF86EF ; (Adr:86..109) 005A: 86EF 005C: 86EF86EF db 86h, 0efh, 86h, 0efh, 86h, 0efh 0060: 86EF db 86h, 0efh, 86h, 0efh, 86h, 0efh 0062: 86EF86EF 298 0066: 86EF db 86h, 0efh, 86h, 0efh, 86h, 0efh 0068: 86EF86EF 299 006C: 86EF db 86h, Offh, 86h, Offh, 86h, Offh ;'1.8V LOBAT' 006E: 86FF86FF 300 ; (Adr: 110..121) 0072: 86FF db 86h, 0ffh, 86h, 0ffh, 86h, 0ffh 0074: 86FF86FF 301 0078: 86FF db 38h, 0bfh, 38h, 0bfh, 38h, 0bfh ;'L.OV LOBAT' 007A: 38BF38BF 302 ; (Adr: 122..133) 007E: 38BF db 38h, 0bfh, 38h, 0bfh, 38h, 0bfh 0080: 38BF38BF 303 0084: 38BF 304 0086: 305 end ``` **EIE/AN91009** #### 1. INTRODUCTION A set of software functions is given to access the E<sup>2</sup>PROM on the 8xC851 microcontrollers. These functions can be called from application programs written in assembly, PL/M-51 or C. The functions are found in the E2PROM.OBJ file that can be linked to the application program. The driver is written and tested with the following software tools from BSO-Tasking: Assembler: ASM51 V3.2 (OM4142) PL/M51: PL/M51 V3.0A (OM4144) C Comp.: C51 V2.0 (OM4136) Debugger: XRAY51 V1.4c (OM4129) Resources used by driver: Exclusive use of 1 register bank (default RB1) Accumulator PSW 1 static bit addressable RAM byte #### 2. FUNCTION DESCRIPTIONS The functions that use write and/or erase actions are interrupt driven except for E2PROM\_wr\_byte\_pol. The application can check the status of these actions by testing the flag E2PROM\_BUSY. This flag is available via the function E2PROM\_status. In the 8xC851, the E²PROM interrupt is combined with the UART interrupt. To enable the E²PROM interrupt, EA (in the IE-register) must be set (should be done in application program), the combined UART/E²PROM enable bit must be set (ES in the IE-register, done with function E2PROM\_int\_en) and the E²PROM interrupt enable bit (EEINT in ECNTRL register) must be set. The E²PROM interrupt flag is automatically set by functions that use erase/write actions. This means that the UART interrupt enable cannot be disabled while the E²PROM interrupt is completely enabled. The E²PROM can be disabled separately with the E2PROM\_int\_dis function. The priority level for UART and E<sup>2</sup>PROM interrupt are the same and are defined with the E2PROM\_int\_en function. The E<sup>2</sup>PROM driver has a link to a UART interrupt handler. When a UART interrupt occurs, the status of the controller is pushed on the stack and then interrupt flags are tested to determine the source of the interrupt. When the source of the interrupt is the UART, then subroutine \_UART\_HDL is called. the implementation of the UART interrupt handler is done by the user. On the disk a file UART.SRC is available that contains this subroutine. This routine will only clear the trx-interrupt flag (TI) and rcv-interrupt flag (RI). EIE/AN91009 #### 2.1 E2PROM init #### **Function description:** This function must be called before any of the other functions is called. The timing register for writing/erasing the E<sup>2</sup>PROM is initialized and the register bank that the E<sup>2</sup>PROM functions can use is defined. The default registerbank is RB1; the ETIM register which determines the write/erase timing is default initialized with 0x7B (XTAL = 12MHz). If other values are required, the parameters REGISTERBANK and XTAL must be changed in the equate list of the source file (E2PROM.ASM). The E<sup>2</sup>PROM/UART interrupt is enabled and set to priority level '0'. #### **Calling Sequence:** E2PROM\_init(); ### **Function prototype:** void E2PROM\_init (void) #### Parameters: None #### 2.2 E2PROM int en ## **Function description:** This function will enable the E<sup>2</sup>PROM/UART interrupt. The global enable bit EA is not effected and must be controlled by the application program. The priority level of the E<sup>2</sup>PROM/UART is controlled by the parameter 'Pr\_Level'. #### **Calling Sequence:** E2PROM\_int\_en (Pr\_Level); #### Function prototype: void E2PROM\_int\_en (data char Pr\_Level) #### Parameters: Pr\_Level: This parameter determines the priority level on which the E<sup>2</sup>PROM/UART interrupts are handled. Values greater than 0x01 will be interpreted as 0x01. #### 2.3 E2PROM int dis #### **Function description:** This function will disable the E<sup>2</sup>PROM/UART interrupt. #### **Calling Sequence:** E2PROM\_Int\_Dis; ### **Function prototype:** void E2PROM\_Int\_Dis (void) ## Parameters: None EIE/AN91009 ## 2.4 E2PROM\_status ## **Function description:** This function will return the E2PROM\_BUSY bit, which indicates whether a read/write transfer from/to the $E^2$ PROM, or an erase action is finished. - '1' indicates that a read/write transfer is still in progress. - '0' indicates that no read/write transfer is in progress. If the application program calls an E²PROM function while another E²PROM function is still in progress, parameters may be overwritten and an erroneous result will be obtained. There are 2 exceptions on this rule. When the functions "E2PROM\_rd\_byte\_pol" or "E2PROM\_wr\_byte\_pol" are called, parameters are passed to different registers in the registerbank, the E2PROM status is stored and the transfer is done by polling. Note that the E2PROM\_BUSY bit is not the same as EWP-flag in the ECNTRL register. For write operations the EWP-flag indicates when the writing/erasing of a byte to the E²PROM is finished. The E2PROM\_BUSY flag indicates when a complete block of data (e.g., from the E2PROM\_wr\_block function) has been written to the E²PROM. ## **Calling Sequence:** bit Status: Status = E2PROM\_Status; # Function prototype: bit E2PROM\_Status (void) #### Parameters: None #### 2.5 E2PROM\_wr\_byte #### **Function description:** This function will write a byte to E<sup>2</sup>PROM. If the source byte has the same value as the byte in the E2PROM, no write action will take place. Byte transfer is done on interrupt basis. The status of the transfer can be checked with the "E2PROM\_Status" function. This function will automatically enable the E<sup>2</sup>PROM interrupt. The application program should take care of the E<sup>2</sup>PROM/UART interrupt enable (with E2PROM\_int\_en) and the EA bit. # **Calling Sequence:** E2PROM\_wr\_byte (Src\_Byte,Dest\_Ptr); # Function prototype: void E2PROM\_wr\_byte (data char Src\_Byte,data char Dest\_Ptr) #### Parameters: Src\_Byte: Byte to be written to E<sup>2</sup>PROM Dest\_Ptr: Address of E<sup>2</sup>PROM EIE/AN91009 ## 2.6 E2PROM\_rd\_byte # Function description: This function will read a byte from E<sup>2</sup>PROM. The status of the transfer can be checked with the "E2PROM Status" function. ## **Calling Sequence:** data char Result; Result = E2PROM\_rd\_byte (Src\_Ptr); ## Function prototype: char E2PROM\_rd\_byte (data char Src\_Ptr) #### Parameters: Src Ptr: Address of E<sup>2</sup>PROM # 2.7 E2PROM wr block # **Function description:** This function will write a block of data from internal RAM to E<sup>2</sup>PROM. Byte transfer is done on interrupt basis. The status of the transfer can be checked with the "E2PROM\_Status" function. This function will automatically enable the E<sup>2</sup>PROM interrupt. The application program should take care of the E<sup>2</sup>PROM/UART interrupt enable (with E2PROM\_int\_en) and the EA bit. If the source bytes are the same as the bytes in the E²PROM, no write action will take place. This function will automatically generate ROW-erases, whenever this will reduce programming time. If during execution of this function, the destination address to the E²PROM is equal to the beginning of an E²PROM row (3 least significant address bits are '0') and at least 8 more bytes have to be programmed, a check will be done whether a ROW-erase will reduce programming time. If no RWO-erase is done, the time to program the ROW will be: $T_{proq} = A.t_W + B.(t_E + t_W)$ A: Byte in E<sup>2</sup>PROM is 0x00; source byte in RAM is not 0x00 B: Byte in E<sup>2</sup>PROM is not 0x00; source byte in RAM <> E<sup>2</sup>PROM byte If a ROW-erase is done, programming the ROW will take: $T_{prog} = t_E + C.t_W$ C: Source byte in RAM <> '0' Because the erase time ( $t_E$ ) and the write time ( $t_W$ ) are equal, the function will do a ROW-erase if A+2.B-C-1 >= 0 ### **Calling Sequence:** E2PROM wr block (Src Ptr, Dest\_Ptr, Nr\_Bytes); #### Function prototype: void E2PROM\_wr\_block (data char \*data Src\_Ptr, data char Dest\_Ptr, data char Nr\_Bytes) #### Parameters: Src\_Ptr: Address pointer to internal RAM Dest\_Ptr: Address of first E<sup>2</sup>PROM byte Nr\_Bytes: Number of bytes to write to E<sup>2</sup>PROM EIE/AN91009 #### 2.8 E2PROM\_rd\_block ## **Function description:** This function will read a block of data from E<sup>2</sup>PROM and store it in internal RAM. The status of the transfer can be checked with the "E2PROM Status" function. #### **Calling Sequence:** E2PROM\_rd\_block (Src\_Ptr,Dest\_Ptr,Nr\_Bytes); # **Function prototype:** void E2PROM\_rd\_block (data char Src\_Ptr, data char \*data Dest\_Ptr, data char Nr\_Bytes) #### Parameters: Src Ptr: Address of first E<sup>2</sup>PROM byte Dest\_Ptr: Address pointer to internal RAM Nr\_Bytes: Number of bytes to read from E<sup>2</sup>PROM # 2.9 E2PROM\_wr\_byte\_pol # Function description: This function will write a byte from internal RAM to E<sup>2</sup>PROM. If the source byte has the same value as the byte in the E2PROM, no write action will take place. If an E<sup>2</sup>PROM function is in progress (except E2PROM\_rd\_byte\_pol), this function will be interrupted but its status will be saved so that the interrupted function will be resumed when the E2PROM\_wr\_byte\_pol function is finished Byte transfer is done by polling. This function may be used, e.g., in interrupt service routines, where the possibility exists that the interrupted main program has already started an E<sup>2</sup>PROM transfer. ### **Calling Sequence:** E2PROM\_wr\_byte\_pol (Src\_Byte,Dest\_Ptr); # Function prototype: void E2PROM\_wr\_byte\_pol (data char Src\_Byte,data char Dest\_Ptr) #### Parameters: Src Byte: Byte to be written to E<sup>2</sup>PROM Dest\_Ptr: Address of E<sup>2</sup>PROM EIE/AN91009 ### 2.10 E2PROM\_rd\_byte\_pol #### **Function description:** This function will read a byte from E<sup>2</sup>PROM. If an E<sup>2</sup>PROM function is in progress (except E2PROM\_wr\_byte\_pol), this function will be interrupted but its status will be saved so that the interrupted function will be resumed when the E2PROM\_rd\_byte\_pol function is finished. This function may be used, e.g., in interrupt service routines, where the possibility exists that the interrupted main program has already started an E<sup>2</sup>PROM transfer. # **Calling Sequence:** data char Result: Result = E2PROM\_rd\_byte\_pol (Src\_Ptr); # **Function prototype:** char E2PROM\_Rd\_Byte\_Pol (data char Src\_Ptr) #### Parameters: Src Ptr: Address of E<sup>2</sup>PROM #### 2.11 E2PROM\_block\_erase #### **Function description:** This function will erase all 256 E<sup>2</sup>PROM bytes. The erase function is done on interrupt basis. The status of the transfer can be checked with the "E2PROM\_Status" function. This function will automatically enable the E<sup>2</sup>PROM interrupt. The application program should take care of the E<sup>2</sup>PROM/UART interrupt enable (with E2PROM\_int\_en) and the EA bit. # **Calling Sequence:** E2PROM block erase(); #### Function prototype: void E2PROM\_block\_erase (void) # Parameters: January 1992 None EIE/AN91009 ## 2.12 E2PROM\_security\_on # **Function description:** This function inhibits access to E<sup>2</sup>PROM from external program memory. The following scheme gives the access possibilities when this function is executed. | EA pin | Address of E2PROM access instruction | Access to E2PROM | | |--------|--------------------------------------|------------------|--| | 1 | < 4096<br>>= 4096 | YES<br>NO | | | 0 | < 4096<br>>= 4096 | NO<br>NO | | The write function is done on interrupt basis. The status of the transfer can be checked with the "E2PROM Status" function. This function will automatically enable the E<sup>2</sup>PROM interrupt. The application program should take care of the E<sup>2</sup>PROM/UART interrupt enable (with E2PROM\_int\_en) and the EA bit. #### **Calling Sequence:** E2PROM\_security\_on(); # **Function prototype:** void E2PROM\_security\_on (void) #### Parameters: None EIE/AN91009 # 2.13 E2PROM\_security\_off ## **Function description:** This function will remove E<sup>2</sup>PROM protection. Access to E<sup>2</sup>PROM from external program memory is now possible if this function is executed from the right program memory. The following scheme gives the possibilities when 'E<sup>2</sup>PROM\_security\_off' is executed after completion of the 'E<sup>2</sup>PROM\_security\_on' function. The following table assumes that the address at which 'E2PROM\_security\_off' resides is smaller than 4096. | EA pin | Address of E2PROM access instruction | Mode | Access to<br>E2PROM | E2PROM<br>erased | |------------------|----------------------------------------|------------------|--------------------------|------------------------| | 1<br>1<br>1 | < 4096<br>>= 4096<br>< 4096<br>>= 4096 | 0<br>0<br>1<br>1 | YES<br>YES<br>YES<br>YES | NO<br>NO<br>YES<br>YES | | 0<br>0<br>0<br>0 | < 4096<br>>= 4096<br>< 4096<br>>= 4096 | 0<br>0<br>1<br>1 | NO<br>NO<br>YES<br>YES | NO<br>NO<br>YES<br>YES | The following table assumes that the address at which 'E2PROM\_security\_off' resides is greater than 4096. | EA pin | Address of E2PROM access instruction | Mode | Access to<br>E2PROM | E2PROM<br>erased | |-------------|----------------------------------------|------------------|------------------------|------------------------| | 1<br>1<br>1 | < 4096<br>>= 4096<br>< 4096<br>>= 4096 | 0<br>0<br>1<br>1 | YES<br>NO<br>YES<br>NO | NO<br>NO<br>YES<br>YES | | 0<br>0<br>0 | < 4096<br>>= 4096<br>< 4096<br>>= 4096 | 0<br>0<br>1<br>1 | NO<br>NO<br>YES<br>YES | NO<br>NO<br>YES<br>YES | # **Calling Sequence:** E2PROM\_Security\_Off; ## **Function prototype:** void E2PROM\_Security\_Off (data char Mode) #### Parameters: Mode: If '0', then the protection will only be removed when this function is executed from internal program memory. When executed from external memory, the protection remains. If '1', then the protection can also be removed when this function is executed from external memory, however, all E²PROM bytes will be erased. EIE/AN91009 #### 3. PROGRAM EXAMPLES Three examples are given that show how to use these functions with C, PL/M51 and assembly programs. In the examples, a string of characters is written to and read from E<sup>2</sup>PROM. When reading back the string, spaces are replaced by underscores. #### 3.1 C example The disk contains the file E2PROM.H that should be included in the C application program. E2PROM.H contains the function prototypes of the E²PROM functions. The example program can be found on the disk in file TEST\_C.C. When the application module is compiled and assembled, it should be linked to the E<sup>2</sup>PROM function module E<sup>2</sup>PROM.OBJ and the UART interrupt handler UART.OBJ. # 3.2 PL/M51 example The disk contains the file E2PROM.DCL that should be included in the PL/M51 application program. E2PROM.DCL contains the external function declarations for the E<sup>2</sup>PROM functions. The example program can be found on the disk in file TEST\_PLM.PLM. When the application module is compiled and assembled, it should be linked to the E<sup>2</sup>PROM function module E2PROM.OBJ and the UART interrupt handler UART.OBJ. When linking, the linking control 'NOCASE' must be used! ## 3.3 Assembly example The disk contains the file E2PROM.MAC which contains the macro definitions of the functions. Including these macro's in the source file eases programming. For instance, the sequence: ``` MOV _E2PROM_rd_block_BYTE ,Src_Ptr ;Pointer to E2PROM MOV _E2PROM_rd_block_BYTE+1,Dest_Ptr ;Pointer to RAM MOV _E2PROM_rd_block_BYTE+2,#Nr_Bytes ;Number of bytes to transfer LCALL _E2PROM_rd_block ;Call function ``` #### can be replaced by ``` %E2PROM_rd_block(Src_Ptr,Dest_Ptr,#Nr_Bytes) ``` The file E2PROM.GLO contains the EXTRN-definitions of the functions and constants that are used by the driver. Only the definitions used by the source program should be included. When the application module is compiled and assembled, it should be linked to the E<sup>2</sup>PROM function module E<sup>2</sup>PROM.OBJ and the UART interrupt handler UART.OBJ. # EIE/AN91009 #### 3.4 Listing of examples #### **LISTING C EXAMPLE:** ``` #include "E2PROM.h" #include <string.h> #define E2PROM_Base_Address 0x58 rom char txt_tab[]= "This is an E2PROM test for 8xC851"' void main(void) data char Data_Buffer[35]; data char Count; /* Initialize E2PROM */ E2PROM_init(); E2PROM_int_en(0x01); /* E2PROM interrupt level 1 */ /* Global interrupt enable */ EA=1; romidmove(&Data_Buffer,&Txt_tab,sizeof(Txt_tab)-1); /* Copy string from ROM E2PROM_wr_block(&Data_Buffer,E2PROM_Base_Address,sizeof(Txt_tab)-1); /* Copy setring to E2PROM */ /* Time to do other useful things while data is being written to E2PROM on interrupt basis while (E2PROM_status()); /* Wait till transfer to E2PROM is finished */ /* Read string from E2PROM and replace spaces " " by underscores "_" */ for (Count=0;Count != sizeof(Txt_tab)-1;Count++) /* Read E2PROM byte */ Data_Buffer[Count] = E2PROM_rd_byte(E2PROM_Base_Address+Count); if (Data_Buffer[Count] == ` ') Data_Buffer[Count] = '_'; } E2PROM_block_erase(); /* Erase E2PROM */ /* Time to do other things while erasing */ while (E2PROM_status()); /* Wait till erasing is finished */ EA=0; ``` EIE/AN91009 # **LISTING PL/M51 EXAMPLE:** ``` $DEBUG $CODE E2PROM: Do; $INCLUDE (E2PROM.DCL) $INCLUDE (UTIL51.DCL) Test: Do; Declare E2PROM_Base_Address literally '58H'; Declare Txt_tab(*) Byte Constant ('This is an E2PROM test for 8xC851'); Declare Data_Buffer(35) Byte Main; Declare Count Byte Main; Call E2PROM_init; /* Initialize E2PROM */ Call E2PROM_int_en(01); /* E2PROM interrupt level 1 */ Enable; /* Global interrupt enable */ /* Copy string from ROM to RAM */ Call MOVCD1(.Txt_tab,.Data_Buffer,length(Txt_tab)); /* Copy string to E2PROM */ Call E2PROM_wr_block(.Data_Buffer,E2PROM_Base_Address,length(Txt_tab)); /* Time to do other useful things while data is being written to E2PROM on interrupt basis Do While E2PROM_status = 1; /* Wait till transfer to E2PROM is finished */ End; /* Read string from E2PROM and replace spaces " " by underscores "_" */ Do Count=0 To length(Txt_tab); /*Read E2PROM byte */ Data_Buffer(Count) = E2PROM_rd_byte(E2PROM_Base_Address+Count); If (Data_Buffer(Count) = ' ') then Data_Buffer(Count) = '_'; End; Call E2PROM_block_erase; /* Erase E2PROM */ /* Time to do other things while erasing */ Do While E2PROM_status = 1; /* Wait till erasing is finished */ End; Disable; End Test; End E2PROM: ``` # EIE/AN91009 ## **LISTING ASSEMBLY EXAMPLE:** ``` $DEBUG $CASE */ ; * */ ;* INCLUDE FILE : E2PROM.GLO */ ; * PACKAGE : E2PROM */ EXTRN CODE (_E2PROM_init) EXTRN CODE (_E2PROM_int_en) EXTRN CODE (_E2PROM_int_en_BYTE) EXTRN CODE (_E2PROM_status) EXTRN CODE (_E2PROM_rd_byte) EXTRN NUMBER (_E2PROM_rd_byte_BYTE) EXTRN CODE (_E2PROM_wr_block) EXTRN NUMBER (_E2PROM_wr_block_BYTE) EXTRN CODE (_E2PROM_block_erase) ;* Include macro definitions $INCLUDE(E2PROM.MAC) BUFFER SEGMENT DATA RSEG BUFFER Data_Buffer: ds 35 ds 1 Count: ds 15 Stack: TABLE SEGMENT CODE RSEG TABLE "This is an E2PROM test for 8xC851" Txt_tab: db EQU 58H E2PROM_Base_Address EQU 33 Length_Txt CSEG AT 00 ;Reset vector LJMP MAIN TEST_ASM SEGMENT CODE RSEG TEST_ASM ;Initialize stack pointer MAIN: MOV SP, #Stack-1 ;Initialize E2PROM %E2PROM_init ;E2PROM interrupt level 1 %E2PROM_int_en(#10) ; Enable global interrupt SETB EA MOV DPTR, #Txt_tab ;Initialize pointers to copy Txt_tab to RAM MOV RO, #Data_Buffer MOV R2, #Length_Txt ``` # EIE/AN91009 ``` COPY_LOOP: ;Copy Txt_tab to RAM CLR A MOVC A, @A+DPTR ;Get byte from ROM MOV @RO,A ;Store in RAM INC DPTR ;Update pointers INC RO DJNZ R2, COPY_LOOP ;Check if all copied ;Write data to E2PROM %E2PROM_wr_block(#Data_Buffer,#E2PROM_Base_Address,#Length_Txt) ; Time to do other useful things while data is being written to ; E2PROM on interrupt basis NEW_CHECK: %E2PROM_status ;Wait till transfer to E2PROM is finished JC NEW_CHECK ;Read string from E2PROM and replace spaces " " by underscores "\_" MOV R0, #Data_Buffer ;Initialize pointers MOV R1, #E2PROM_Base_Address MOV R2, #Length_Txt READ_LOOP: %E2PROM_rd_byte(R1) MOV @RO,A ;Store byte in RAM CJNE A, # " ", NEXT_READ ; Check if byte is " " MOV @RO, #"_" ;If yes, replace with "_" NEXT_READ: INC RO ;Update pointers INC R1 DJNZ R2, READ_LOOP %E2PROM_block_erase ;Erase E2PROM ; Time to do other things while erasing */ NXT_CHECK: %E2PROM_status ;Wait till transfer to E2PROM is finished JC NXT_CHECK CLR EA ;Disable interrupts JMP $ ; End of program ``` EIE/AN91009 #### 4. DEBUG MACROS The disk contains some debug macros that ease the debugging of programs that use the 8xC851 E<sup>2</sup>PROM. These macros can be executed by the XRAY51 High Level Language debugger. The user can read from and write to E<sup>2</sup>PROM bytes without programming the individual SFRs. Before the macros can be executed, they must be loaded by XRAY51. This will be done automatically if the file 'E2PROM.INC' is included when invocating XRAY51 or during a debug session. E2PROM.INC will load the macros and define some symbols used by the macros. If not all macros are used, the file E2PROM.INC can be edited to prevent the loading of these macros. This may be necessary when there is insufficient memory to load the macros, because, for instance, other macros have been loaded. Another advantage of only loading the relevant macros is reduction of loading time. When a macro is called from the debugger, the following SFRs will remain unchanged: ECNTRL, EADRH, EADRL and ETIM. During macro execution, all interrupts will be disabled. Access to the E<sup>2</sup>PROM with the macros is independent of the state of the security bit. The execution and results of the macro are visible on the I/O screen of XRAY51 (VSCREEN 3). #### Read(Start address, Stop address): The value of E<sup>2</sup>PROM bytes from 'START ADDRESS' to 'STOP ADDRESS' will be shown. If 'START ADDRESS' <= 'STOP ADDRESS' only the value of 'START ADDRESS' will be shown. #### Write(Start address, Stop address, Value): The E<sup>2</sup>PROM bytes from 'START ADDRESS' to 'STOP ADDRESS' will be programmed with 'VALUE'. If 'START ADDRESS' > 'STOP ADDRESS', no E2PROM bytes will be programmed. If the ETIM register contains the value 0x08, it is considered that ETIM is not initialized. The macro will give a warning, and return to the debug screen. #### Copyto(Ram address, E2PROM address, Count): Macro will copy 'COUNT' bytes, starting from internal RAM address 'RAM ADDRESS' to the E<sup>2</sup>PROM, starting at address 'E2PROM ADDRESS'. If during copying, the RAM address becomes > 0x7F or the E<sup>2</sup>PROM address becomes > 0xFF, copying will be stopped and a warning is given that an address limit is reached. If the ETIM register contains the value 0x08, it is considered that ETIM is not initialized. The macro will give a warning, and return to the debug screen. # Copyfrom(E2PROM address, Ram address, Count): Macro will copy 'COUNT' bytes from E<sup>2</sup>PROM address 'E2PROM ADDRESS' to the internal RAM, starting at address 'RAM ADDRESS'. If during copying, the RAM address becomes > 0x7F or the E<sup>2</sup>PROM address becomes > 0xFF, copying will be stopped and a warning is given that an address limit is reached. #### Erase(): All E<sup>2</sup>PROM bytes will be erased. If the ETIM register contains the value 0x08, it is considered that ETIM is not initialized. The macro will give a warning, and return to the debug screen. EIE/AN91009 #### 5. CONTENTS OF DISK The disk contains the following 3 directories: #### USER This directory contains the files that may be included or linked to the source program. E2PROM.ASM :Source file of E2PROM driver E2PROM.OBJ :Object file of E2PROM driver E2PROM.H :Header file for C applications E2PROM.DCL E2PROM.MAC :Declaration file for PL/M51 :Macro definitions for assembly applications E2PROM.MAC :Global definitions for assembly applications E2PROM.GLO UART.SRC :UART interrupt handler (will only clear flags; user should customize it) UART.OBJ :Object file of UART interrupt handler #### 2. \DEBUG This directory contains the macros and include file used with XRAY51 debugger. E2PROM.INC :Include file that reads macro files in XRAY51 \*.MAC :XRAY51 macros ### 3. \EXAMPLE This directory contains the source files of the example programs described in the note TEST\_C.C :C example TEST\_PLM.PLM TEST\_ASM.ASM :PL/M51 example :ASM51 example # Low RF-emission applications with a P83CE654 microcontroller **EIE/AN92001** # 1. Introduction Quite recently customers asked for dedicated 8-bit microcontrollers at high clockrates which would not cause Radio Frequency (RF-) disturbances in consumer and communication applications, e.g. key-board control, tuning, etc... Up to now either a slower 4-bit microcontroller was used or a more modern 8-bit microcontroller is in use with additional RF-shielding and filtering measures. With a carradio manufacturer, a bargain was set for a new (EMC friendly) 8-bit microcontroller such that the product would maintain equal receiving performance with more control features. The new receiver would then only be modified for the microcontroller part. To set the emission requirements, for a microcontroller in this application, the measurement technique described in the application note, EIE/AN91001 "Workbench EMC evaluation method", was used and applied to the existing receiver in which the new microcontroller has to fit in. Later on, the same technique was used to verify the basic and modified samples which contained one or more measures to reduce RF-emission. Each (mask) shrinking event will cause circuits to become faster and produce more RF-disturbances for these kind of appliances. As such, more EMC measures need to be taken after each shrinking event to maintain the above set emission requirements. #### 2. Measures to reduce RF-emission Up to now, evident measures are known to reduce RF-emission. Within a few years time, new techniques will mature to keep pace with shrinking actions. So far it is only interesting to take emission reducing measures on-chip for a microcontroller when there are no external ROM, RAM or (E)EPROM-busses. The externally required data- and address-busses will cause much more RF-radiation, when used in a non-shielded way. We've restricted ourselfs to stand-alone controllers, which can control most functions locally with, when required low speed serial busses e.g. I<sup>2</sup>C (100 kbit/s or 400 kbit/s with output-edge-control), or parallel communication to another controller. To compare our results, reference is made to an existing standard microcontroller based on the INTEL 80C51-core mounted in a 40 pin DIL package. Dedicated software has been used to allow true comparison between all microcontrollers in a defined application. April 1992 715 # Low RF-emission applications with a P83CE654 microcontroller EIE/AN92001 # 2.1 IC-package Density problems demand smaller packages to allow further integration of functions within a certain product size. It was decided to take the Quad Flat Pack (QFP) 44, because it was the lowest pin number package available above the 40 pins required to apply the circuit as stated above. The advantage of this package is the smaller loop area enclosed by the currents running through the circuit. As a result, direct radiation will be reduced. The worst-case area difference between the package sizes is: DIL 40: $48,46 \times 15,24 \times 4,3 \text{ mm} (1 \times w \times h, h = PCB + die-path height)$ diagonal: 50,8 mm looparea: 218,5 mm<sup>2</sup> QFP 44: $11.4 \times 8.8 \times 1.2 \text{ mm} (1 \times w \times h, h = \text{die-path height})$ diagonal: 14,4 mm looparea: 17,3 mm<sup>2</sup> When package radiation is considered only, the magnetic dipole moment produced by the package will be reduced by a factor of 12,6, which can give a decrease in electromagnetic emission of about 22 dB. External supply decoupling capacitors can be placed more closely to the pins where needed. The latter will shorten the length of the current path between Vdd and Vss, thus resulting in a lower voltage drop appearing in-between reference point taken on the PCB. Considering this, the current path reduction will be a factor of 4,5 which would result in an RF-emission reduction of about 12 dB. One should consider that also I/O-pins will contribute to the RF-emission. Practical radiation figures have shown a decrease of about 12 dB. ## 2.2 IC-pinning As already given above, supply and I/O pinning will determine emission performance, due to the fact that radiation is determined by the way currents flow through a device. For some years it is known that each output pin should be embedded in-between a Vdd and a Vss pin. As such, the 3 one-byte wide busses would need 3x(2x8 + 1) pins (O, Vdd, Vss), equals at least 51 pins. For such a device this seems unpractical. The advantage of such a pinning will be that currents will always flow through adjacent leadframe fingers and as such, emission will be absolutely minimal. For this application, I/O will commonly occur at low frequencies, and as such, their contribution to RF-emission will be low. In CMOS applications these currents will mainly occur during transitions by charging and discharging the output load. A more serious contribution will arise from the ground-bounce or supply-bounce which will occur between the PCB-reference and the IC's-substrate. This disturbance voltage will be superimposed to all I/O's which are either coupled to Vss or Vdd. When these lines are long, longer than the path involved for supply decoupling, their contribution to radiation April 1992 716 Philips Semiconductors Application note # Low RF-emission applications with a P83CE654 microcontroller EIE/AN92001 can be high. The disturbance source, being the supply- or ground-bounce voltage, has a negligible impedance ( $\omega$ .L, L = leadfinger + bondingwire inductance) and will be difficult to filter by using simple and cheap components such as capacitors. More often, radiation will increase by such measures due to the increased current through these I/O's. The most effective action will be the use of several ground and supply pins. The ground pins must be spread around the circumference of the package while the supply pins need to be the adjacent to these grounds to benefit the mutual coupling in-between. This mutual coupling reduces the 'effective' series inductance with the external decoupling capacitor. With the DIL 40, pin 20 is de Vss-pin as pin 40 is the supply pin, Vdd. The I/O-pins are randomly located. With the QFP-44, for the Vss the following pins are selected: 6, 16, 28, 39 and the supply pins are: 17 (for I/O) and 38 (for the core). Another cause for ground-bounce can be the X-tal oscillator's output with its external capacitance. Normally, this contribution can be reduced by adding some series impedance with the output and changing the capacitors values such that the X-tal circuit operation remains within its linear range with sufficient amplitude. All together, the ground-bounce, which will be emitted by the I/O, can be reduced by a factor of 4 (4 gnd pins QFP versus 1 gnd pin DIL), assuming random I/O current distributions. Individual decoupling of the I/O and core supply will dampen the supply bounce even further. As such these measures will reduce emissions further by some 12 dB. The expectation of even more drastic effects can be accounted for by the shorter leadframe finger lengths comparing DIL 40 to QFP 44. # 2.3 On-chip decoupling measures From the above, it will be clear that RF-emission will primarily come from the core and that the lower frequencies will be mainly caused by the I/O. For the latter output-edge-rate control can be considered, when the number of outputs are high compared to the number of Vss and Vdd pins. When core decoupling is integrated, the high frequency low energy currents can close their loop on silicon. As a result these RF-currents will not flow through the leadframe any longer and will not add to any additional ground-bounce. If the latter is implemented without further considerations, the effect can be quite negative. The original circuit design assumed that all charge (current) comes from the external decoupling capacitor. This charge (current) then, flows from the capacitor, through its leadwires, PCB traces, IC leadframe, interconnect to the circuit (that needed it) and then back. When on-chip decoupling is used, charge is there and switching will occur instantaneously. In our case, most bus-driving circuits were re-designed such that waveforms maintain within their specifications under worst-case conditions (temperature, supply voltage, etc.). The overall result is that on-chip decoupling will require little space due to the fact that all April 1992 717 # Low RF-emission applications with a P83CE654 microcontroller EIE/AN92001 empty areas can be used, even within the circuit-blocks, and that bus-driving circuits can be made much smaller with respect to the present dimensions. # 2.4 PCB design measures The QFP-package and the pinning of the controller will only reduce the RF-emission when the PCB is laid out following some constraints. An example of a good supply and ground plane lay-out is given in Fig.1. The microcontroller is mounted on the component side of a double layer PCB. The supply pairs Vss1/Vdd1 for the I/O-supply and Vss3/Vdd2 for the core supply are connected directly to the ceramic chip capacitors C1 and C2, which are surface mounted on the solder side. A short connection of Vss3/Vdd2 to the capacitor C2 minimizes loop inductance. Thus, the external supply current drawn by the core will flow in this loop mainly. This current path can be ensured by the insertion of an inductor (L2) in series to the +5V general supply. An equal action is taken for the I/O-supply. The implemented on-chip decoupling allows a separation between core and I/O-ports. The PCB lay-out shall use these Vdd/Vss connections to minimize the loop areas in-between signal lines from each port pin to any load via the ground plane back to these Vss/Vdd-pins. By applying these hints, Vss2 may be used as the return pin for ALE, PSEN, port0 and port2 because Vss2 is connected very near to them. Vss3 shall be used for the core supply mainly. Vss1 is nearest to lower part of port2, upper part of port3 and the crystal oscillator. Even though Vss1 may be the best return for port2 and port3, this pin shall in any case be used as return for the external crystal oscillator capacitors (not shown here). Vss4 is located nearest to the lower part of port3 and the whole port1, being the best return for these ports. # 3 Future developments Existing products are shrunk, to cut costs and increase complexity. Recent developments $(SAC3 \rightarrow SAC2 \rightarrow SAC1, C300 \rightarrow C250 \rightarrow C200)$ and others) have demonstrated an upwards tendency in the RF-emission following shrinking when EMC is not considered. This means that the end in taking measures to reduce RF-emission has not been reached. Further improvements are still possible an already considered for new products, such as: - a PLL-circuit, to replace the high frequency X-tal oscillator, - output-edge-control (application dependent), - further circuit improvements on-chip e.g. coplanar supply, decoupling measures within cell-blocks, multi-phase clock systems to prevent simultaneous switching #### 4 Results All measurements were carried out under the same conditions, using the same kind of PCB, with the same software and the same bus loadings, Fig.2. Philips Semiconductors Application note # Low RF-emission applications with a P83CE654 microcontroller EIE/AN92001 Tested were the following applications: ``` ☞ 1 87C51, DIL 40. 12 MHz X-tal \rightarrow 0 \text{ dB(rel)} ≈ 2 80C31, OFP 44, \rightarrow 13 dB but with 2 Vss and only one Vdd connection, 12 MHz X-tal ☞ 3 83CE654, OFP 44, with Address Latch Enable \rightarrow 32 dB (ALE) active, 12 MHz X-tal 4 Vss and 2 Vdd pins as given above. ■ 4 83CE654, QFP 44, ALE off, 12 MHz X-tal \rightarrow 50 dB ☞ 5 83CE654, QFP 44, ALE off, externally 12 MHz, \rightarrow 54 dB 500 mV sinewave. ``` #### 5 Conclusions With the measures indicated in chapter 2, RF-emission can be reduced substantially, especially for stand-alone microcontroller applications. Up to now, a number of measures have been implemented which indicate a improvement of about 40 dB in the FM-region when changing from a DIL 40, annex 1 to a QFP 44 application, annex 4, taking into account minor additional supply measures. The inclusion of a PLL can make the improvement even further to about 50 dB, annex 5. With these measures, some 12 to 22 dB can be accounted for by the choice of the package, same 12 dB due to the pinning and the rest due to the internal measures. The advantage of these measures can be easily wasted by insufficient measures on the PCB. Constraints are given in chapter 2.4. When considering the reducing effects PCB-layouts might have to RF-emission, the following relative information needs to be considered: ``` single layer board → 0 dB (relative) double layer board → 26 dB (best case) multi layer board → 44 dB (4-layer, best case) ``` #### 6 References - [1] Syllabus of the design course "Fast digital and analog circuit design", Philips CTT, 1991, Eindhoven - [2] IC package outlines, Philips Components, 1990, 12NC: 9398 175 80011. - [3] Improvements in microcontrollers for a better EMC behaviour, H.Schutte, EIE/IN90039 version 2, 1991 - [4] Investigations on EME improvements for the microcontrollers 8xCE592 and 8xCE598, H-W Lütjens, HKI/IR 92001, 1992 April 1992 719 Fig.2 Circuit diagram of tested applications. 722 Annex.2 RF-emission from a 80C31, QFP 44, but with 2 Vss and only one Vdd connection, 12 MHz X-tal. Annex.3 RF-emission from a 83CE654, QFP 44, with Addres Latch Enable (ALE) active, 12 MHz X-tal. 4 Vss and 2 Vdd pins as given above. 724 Annex.4 RF-emission from a 83CE654, QFP 44, ALE off, 12 MHz X-tal. Annex.5 RF-emission from a 83CE654, QFP 44, ALE off, externally 12 MHz, 500 mV sinewave. Philips Semiconductors Application note # Using the analog-to-digital converter of the 8XC552 microcontroller #### **EIE/AN93017** Author: Theo van Daele, Philips Semiconductors Product Concept & Application Laboratory Eindhoven, the Netherlands #### SUMMARY On the 80C552 microcontroller, an 8-input 10-bit ADC is available. To get correct results from the ADC, the slew-rate of the input signal during sampling must be limited. 10 Bit accuracy will be obtained if the layout of the 80C552 application is done correctly. EMC measures must be taken into account. Some software examples are given on how to use the ADC. #### 1.0 INTRODUCTION The 80C552 microcontroller has an on-chip ADC. The converter consists of an 8 input analog multiplexer, and a 10-bit binary successive approximation ADC. A conversion takes 50 machine cycles (is 20µs at 30MHz oscillator frequency). The ADC has dedicated analog supply and reference voltages to minimize influence form digital circuitry. The DAC of the successive approximation ADC is a resistor ladder network. This ensures that there no missing codes. To obtain the 10-bit accuracy, it is important to pay attention to the design of the application. First the operation of the ADC will be described. Then design and layout subjects are described that can influence the accuracy of the conversion result. #### References: - 4. 80C51-based 8-bit microcontrollers (Data Handbook IC20 1994) - Electro Magnetic Compatibility and Printed Circuit Board (PCB) Constraints (ESG89001) #### 2.0 INTERNAL OPERATION OF THE ADC #### 2.1 General Description Figure 1 shows a general block diagram of the ADC. The inputs of P5 are connected to a multiplexer and an input buffer with Schmitt-trigger inputs. When the digital value on P5 must be read (e.g., with a MOV A,P5 instruction), the output of the Schmitt-trigger is taken. This output can be used for further processing. An analog input signal on P5 that must be converted is selected by the input multiplexer. The bits ADCON.0.. ADCON.2 of the ADCON special function register select the input signal. The output of the multiplexer is connected to the input of a comparator. The sampling capacitor is included in the comparator. The ADC control block of the ADC controls the timing of the sampling and conversion. After the input signal is sampled, the actual analog-to-digital conversion starts. The comparator compares the input signal $\rm V_{IN}$ with the output of the 10-bit DAC $\rm V_{DAC}.$ The output voltage of the DAC is determined by the output of the successive approximation register (SAR). The range of the DAC signal varies between AV\_{REF\_and AV\_{REF\_}.} These two signal levels also define the voltage range of the input signal. Figure 1. ## **EIE/AN93017** #### 2.2 Conversion Process Figure 2 shows an example of the conversion principle with 3 bit resolution. The SAR will make its output bits SAR2 . . SAR0 successively high from MSB to LSB. Every time a SAR-line is made HIGH, a DA-conversion will take place. If the output of the DAC ( $V_{DAC}$ ) is higher than the input voltage ( $V_{IN}$ ), the SAR output bit that was made HIGH the last time will be made LOW. If $V_{DAC}$ is smaller than $V_{IN}$ , the SAR output bit will remain HIGH. The process will proceed for the subsequent SAR output bits. At the end of the conversion, $V_{DAC}$ has converged to a value of $V_{IN}\pm^1/_2LSB$ . Example: $V_{\text{IN}}$ is 11/16\* $V_{\text{REF}}$ The conversion sequence is shown in Table 1. After STEP 3 the conversion is finished. The SAR register contains the result of the AD-conversion. The ADC in the 80C552 has 10 bits resolution. The conversion in this ADC will take 10 conversion steps. Table 1. | | SAR Value<br>(SAR2.SAR1.SAR0) | V <sub>DAC</sub><br>(*V <sub>REF</sub> ) | Output Comparator | Action by SAR | |--------|-------------------------------|------------------------------------------|-------------------|----------------| | START | 000 | 0 | 0 | SAR2=1 | | STEP 1 | 100 | 4/8 | 0 | SAR1=1 | | STEP 2 | 110 | 6/8 | 1 | SAR1=0, SAR0=1 | | STEP 3 | 101 | 5/8 | 0 | | Figure 2. Philips Semiconductors Application note # Using the analog-to-digital converter of the 8XC552 microcontroller #### **EIE/AN93017** #### 2.3 The ADC in the 80C552 Figure 3 shows a block diagram of the implementation of the ADC in an 80C552 microcontroller. The analog input signal $V_{IN}$ is connected to the non-inverting input of the comparator via switch S1 during the sampling interval. Internally the comparator consists of 3 serially connected sampled-data-comparator stages $A_1 \dots A_3$ . The stages are capacitively coupled. The coupling capacitor of the first comparator that is connected to S1 will also act as sample capacitor for $V_{IN}$ . Sampled-data-comparators are used to minimize the effect of offsets and temperature drive. During the sampling interval, the value of the offset voltage of the comparator stages are stored on the coupling capacitors. This voltage will have the opposite sign of the comparators stages' offset, so it will cancel this offset voltage. This process is called auto-zeroing, and will be explained in 2.3.2. The non-inverting input of the comparator is connected to $^{1}/_{2}$ V<sub>REF</sub> via switch S2. S2 consists of 2 parallel switches. There is always 1 switch closed, so the voltage on this input is always $^{1}/_{2}$ V<sub>REF</sub>. Although S2 looks superfluous from a functional point of view, it assures that, for instance, switching glitches of S1 and S2 appear on both inputs of the comparator and will cancel each other. When the sampling is finished, the actual conversion will start. S1 will connect the inverting input of the comparator with the output of the DAC. At this moment, the output of the DAC is connected to the center tap of the resistor network. The voltage on the inverting input of the comparator will be $^{1}/_{2}V_{\text{REF}}$ ( $V_{\text{REF}}$ is defined as $^{1}/_{2}[V_{\text{ref+}}-V_{\text{ref-}}]$ ). During conversion, the output of the SAR will determine which tap of the ladder-network will be connected to the inverting input. Using a ladder-network guarantees a monotonic characteristic of the DAC. This in turn will result in an ADC-characteristic without missing codes. The relative deviations of the resistor values result in a non-linear transfer characteristic. The following three phases in the ADC conversion can be determined and will be described in more detail: - Start phase - Sampling phase - Conversion phase. Timing of these phases is shown in Figure 4. #### 2.3.1 Start Detection Phase An ADC conversion can be started by software or by a hardware trigger on the STADC pin. #### Software start When an ADC start is initiated by software (set ADCS in ADCON register), the internal start signal will immediately be active at S6P2 (for state timing, see [Reference ]). The value of ADCS can be read by software. However, there is a delay of 2 machine cycles between the internal start signal and the ability of reading a '1' from ADCS. #### Hardware start A hardware start of an ADC conversion is initiated by a rising edge on STADC. The 80C552 samples STADC every machine cycle during S6P2. When a valid edge is detected, the internal start signal will be active at S1P2 in the subsequent machine cycle. To ensure that the edge is detected, the high and low time should be at least 1 machine cycle each. When a valid edge is detected, 'ADCS' is set. Figure 3. 729 1994 Jun 28 EIE/AN93017 Figure 4. #### 2.3.2 Sample Phase The 8 machine cycles following the start detection is the sample interval (Figure 4). In this time interval, the input signal is sampled and the 3 comparator stages are auto-zeroed. The actual sampling of the analog input signal on the input capacitor starts at machine cycle '2' (Figure 4). The sample capacitor is connected between $V_{\rm IN}$ and the output of the first comparator state (Figure 3). The sampling is finished at the end of machine cycle '5'. After this machine cycle, the sample capacitor is connected between $V_{\rm IN}$ and the input of the first comparator stage. Since this is a very high impedance input, no extra charge will be stored in the sampling capacitor. At the start of the sample phase, the inverting input of the comparator is connected to $V_{IN}$ via a coupling capacitor. This coupling capacitor also serves as sampling capacitor. The non-inverting input is connected to the DAC via a coupling capacitor to a voltage of $1/2V_{REF}$ . Figure 5 shows the sampling and auto-zeroing of the first comparator stage. When the RESET1=1, switches will connect the outputs of the individual comparator stages to their inputs. The outputs will settle to the unity-gain output voltage $V_{UG}$ . The differential voltage (error voltage) on the inputs of the first comparator stage will be: $$V_{IL} = V_{OL} = -V_{OS1} \times \frac{A_1}{A_1 + 1}$$ V<sub>IN</sub> = Input voltage of ADC V<sub>IL</sub> = Differential input voltage of first comparator stage V<sub>OL</sub> = Differential output voltage of first comparator stage V<sub>OS1</sub> = Offset voltage of first comparator stage A<sub>1</sub> = Open loop gain of first comparator stage The switches are opened when RESET1=0. The differential voltage on the comparator inputs is still $V_{\rm IL}$ because of the stored charge on the coupling capacitors. The resulting offset voltage $V_{OS1,l}$ seen on the input of the comparator stage is obtained by adding this differential voltage $V_{IL}$ to the input offset voltage $V_{OS1}$ . $$V_{OS1,I} = V_{OS1} + V_{IL} = V_{OS1} \times \left(\frac{A_1}{1 + A_1}\right)$$ The effective offset voltage at the input of the comparator stage is reduced with a factor $(1+A_1)$ . The auto-zeroing procedure described above will be repeated successively for the following 2 stages. After auto-zeroing the third comparator stage, the differential output voltage of the total comparator (all 3 comparators in series will be: $$V_{O,3} = A_3 \times \frac{V_{OS3}}{1 + A_3}$$ This voltage can be translated to an effective input offset voltage by dividing it by the total gain of the comparator: $$V_{OS,I} = \frac{V_{OS3}}{A_1 \times A_2 \times (1 + A_3)}$$ If auto-zeroing was not used, and all comparator stages were DC-coupled, the differential output voltage of the comparator would be: $$V_{O3} = A_1 \times A_2 \times A_3 \times V_{OS1} + A_2 \times A_3 \times V_{OS2} + A_3 \times V_{OS3}$$ The effective input offset voltage in this case is: $$V_{OS,I} = V_{OS1} + \frac{V_{OS2}}{A_1} + \frac{V_{OS3}}{A_1 \times A_2}$$ As can be seen, the auto-zeroing reduces the effect of the individual comparator stages considerably. #### EIE/AN93017 Figure 5. Figure 6. 731 #### 2.3.3 Conversion Phase Just before the sampling phase is finished, the following voltages are present over the coupling capacitors of the first comparator stage: Capacitor on inverting input: $V_{IN} - V_{UG}$ Capacitor on non-inverting input; $^{1}/_{2}V_{REF} - V_{UG}$ For clarity, the offset voltages are neglected. When the conversion phase is started, S1 (Figure 6) will connect the coupling capacitor of the inverting input to the output of the DAC. The effective voltage on the comparator input is the voltage applied to the coupling capacitor minus the voltage that was stored on the capacitor during the sampling phase. The following voltages are present on the input of the first comparator stage: Inverting input: $V_{DAC} - V_{IN} + V_{UG}$ Non-inverting input: Vug The comparator stage amplifies the differential voltage between its inputs. The output voltage of the first comparator stage will be: $$V_{OL} = A_1 \times (V_{UG} - (V_{DAC} - V_I + V_{UG})) = A_1 \times (V_I - V_{DAC})$$ After amplification by the 3 comparator stages the input signal for the SAR is $\text{IA}_1 \times \text{A}_2 \times \text{A}_3 \times (\text{V}_{\text{IN}} - \text{V}_{\text{DAC}})\text{I}.$ Depending on the sign of this signal, the SAR will set or clear the MSB. In the following cycles of the conversion, the other bits of the SAR will be updated. At the end of the conversion $\text{V}_{\text{DAC}}$ will have a value of $\text{V}_{\text{IN}}\pm 0.5\text{LSB}.$ The contents of the SAR that generates this $\text{V}_{\text{DAC}}$ is the result of the AD-conversion. 1994 Jun 28 Philips Semiconductors Application note # Using the analog-to-digital converter of the 8XC552 microcontroller EIE/AN93017 #### 3.0 APPLICATION INFORMATION Although the ADC in the 80C552 has a resolution of 10 bits, the user must be careful in the design of the application to really get this resolution. The constraints can be divided in 2 categories: - Constraints on the analog input signal and the input signal source - Layout constraints of the design. #### 3.1 Analog Input Signal Constraints #### 3.1.1 Range of Analog Input Signal The value of the analog input signal must be between $V_{REF+}$ and $V_{REF-}$ . The span of the analog input signal is $V_{REF} = (V_{REF+} - V_{REF-})$ . There is a minimum limit to the span. This limit depends on the gain of the comparators. A differential voltage of 1LSB (1LSB = $V_{\text{REF}}/1024$ ) on the inputs of the comparator should be able to generate a logic '1' or '0' level on the input of the SAR. If not, the resolution of 10 bits for the ADC will not be met. the comparator in the 80C552 needs a minimum differential input voltage of 0.3mV to generate a valid logic output level. For the 10-bits ADC in the 80C552, this means that $V_{REF}$ should be at lease $1024^*0.3mV=0.31V$ to get 10-bit resolution. The absolute values of $V_{REF+}$ and $V_{REF-}$ that determine this span may not exceed AVSS and AVn. #### 3.1.2 Slew Rate of Analog Input Signal A distinction must be made between 2 different slew-rate constraints. The first slew-rate constraint deals with the required accuracy during sampling. The second constraint to prevent wrong readings deals with a limitation on the slew rate that may otherwise lead to a conversion result that has no relation at all with the analog input signal. 1: To obtain a stable reading from the ADC, the analog input signal should be stable during the sampling time. The sampling may be triggered by an external event (via ADEX pin). From this trigger point until machine cycle '5' (see Figure ), the input signal is sampled and should not change more than the desired accuracy. **Example:** If a stability of 0.5LSB is required, then the analog input signal should not change more than 0.5LSB in 6 machine cycles. In that situation the maximum slew-rate of the analog input signal is: $$\frac{dV}{dt} = \frac{0.5LSB}{6T}$$ where T is the machine cycle time. The following graph gives the maximum slew-rate as function of the operating frequency for various values of $V_{REF}$ and a required stability of $^{1}/_{2}LSB$ for a 10-bit conversion. When the slew-rate of the input signal is more than the maximum slew-rate as determined above, the read-out stability will decrease. The conversion result will be the digital value of the input signal somewhere between machine cycle '0' and machine cycle '5'. Consecutive conversions of a signal that consists of a DC-value with an AC-component that has high slew-rates as mentioned above, and that has the same amplitude between machine cycle '0' and machine cycle '1', may give different read-outs. However, the accuracy of the sampled signal will not be affected. 2: If the slew-rate exceeds a certain value, the accuracy of the conversion will decrease rapidly. The result of the conversion will not have any result anymore with the analog input signal. Tests have shown that the most probable conversion result is 0x3ff (result bits ADS.0.. ADC.9 are '1'). This error situation will occur when the slew rate is too high in the time frame from machine cycle '2' to machine cycle '9' of the conversion. In this time frame, the comparators are auto-zeroing their offsets. For proper auto-zeroing, the comparator stages must work in their linear region. If the input signal is changing rapidly, the voltage change may couple through the coupling capacitors to the input of the comparator stage. If this voltage change is sufficiently high, it may saturate the comparator stage. The comparator stage is not working in its linear region anymore, and the saturation voltage (equal to about the supply voltage) is stored on the coupling capacitors. The ADC has the highest sensitivity to these high slew-rate signals in the time frame from machine cycle '8' to machine cycle '9'. In this time frame the RESET switches of comparator stage 1 and 2 are open; the RESET switch of comparator stage 3 is closed for auto-zeroing. An analog input signal with sufficient slew rate may couple through to comparator stage 3 via the coupling capacitors of stage 1 and 2. The high sensitivity comes from the fact that the signal is amplified by comparator stages 1 and 2 before it reaches the input of comparator stage 3. When the saturation voltage is stored on the coupling capacitors, the following comparator stage is not useful anymore to determine the sign of $IV_{IN}-V_{DAC}I$ . Suppose the coupling capacitors on the input of the second comparator stage are charged to the saturation voltage $V_{SAT}$ . The differential output voltage of the first comparator stage will be $A_1\times (V_{IN}-V_{DAC})$ . This signal is fed to the input of the second comparator stage whose output signal will be $A_2\times [A_1\times (V_{IN}-V_{DAC})\pm V_{SAT}]$ . Since the differential output voltage of the comparator stages can never be higher than $\pm V_{SAT}$ , the output of this comparator stage will stay at its saturation level, independent of the value of $(V_{IN}-V_{DAC})$ . EIE/AN93017 The only way to avoid the error mentioned above is to limit the slew rate during the sampling interval (machine cycle 2 to 9). For the ADC in the 80C552 the slew rate of the analog input signal must be lower than 10V/ms. From the discussion above, it becomes evident that it is essential that the slew-rate of the input signal is limited to 10V/ms. Although 'clean' DC signals may be applied to the ADC, noise spikes or crosstalk from neighboring signals may still result in signal components with a slew-rate >10V/ms on the DC signal during the sampling interval. The following measures can be taken to reduce the slew rate on analog input signals: - Supply the analog signal from a source with low output impedance. This will reduce the sensitivity to cross-talk. - Keep the analog input signal lines away from digital signal lines. Analog signals may be screened from digital signal lines with a grounded guard ring on the PCB. - Do not mix analog and digital signals on P5 pins. - Connect an RC filter to the analog inputs. The time constant should be ≥500µs. For a $5V_{PP}$ input sine-signal, the slew rate constraint of 10V/ms results in a maximum input frequency of 637Hz. When we use the Nyquest criterion ( $f_{SAMPLE} \ge 2^+f_{SIGNAL}$ ), the maximum input signal frequency is 1kHz when the 80C552 runs on 1.2MHz (1 conversion every $500\mu s$ ). This shows that the maximum input signal frequency for the ADC of the 80C552 is determined by the **slew-rate**. So, increasing the XTAL frequency on which the 80C552 is operating, does not automatically imply that the maximum input signal frequency also scales to a higher value. This scaling is only allowed for signals with a slew rate <10V/ms. #### 3.1.3 Analog Signal Drive The output resistance of the analog signal source should be small enough not to add a significant error to the conversion result. The output impedance has two effects on the accuracy of the conversion, that is, the voltage drop over the source resistance and the time constant to charge the sampling capacitor. 1: The voltage drop over the output impedance due to the input current of the ADC. In the 80C552, the input current is a leakage current. this leakage current is specified as less than $1\mu A$ . Practically, however, the leakage current will be less than 100nA. Figure 7. Figure 7 shows the input circuit. The leakage current comes mainly from circuitry directly connected to the P5.x pin. Compared with this leakage current, the input current of the comparator can be neglected. $C_{\rm S}$ represents the contribution of the stray capacitances; $C_{\rm C}$ represents the sampling capacitor. Before the sampling capacitor, there is the series resistance $R_{\rm M}$ of the analog multiplexer. The output resistance $R_S$ of the input signal source will cause a voltage drop due to the input leakage current. The voltage that will be converted is the voltage on the sampling capacitor. This voltage is the input voltage $V_{IN}$ minus the voltage drop over $R_S$ . This voltage drop will give an error contribution in the conversion result of $V_{IN}$ . When an accuracy of $^{1}/_{2}LSB$ is required, the maximum source resistance $R_{S}$ is: $$R_S < \frac{0.5LSB}{I_I}$$ **Example:** If $V_{REF}$ = 5.12V and $I_{I}$ = 1 $\mu$ A, the source resistor should be less than 2.5k $\Omega$ . When this constraint on output resistance of the signal source cannot be met, the analog signal should be buffered with a buffer of sufficiently low output resistance. this buffer should be placed as close as possible to the analog source. the longer leads from buffer to the ADC input will be less sensitive to cross-talk (low impedance source resistance) than long leads from signal source to buffer (high impedance source resistance). Filtering may be included in the buffer stage to limit the slew-rate of the signal to <10V/ms. 2: The ability to charge the sampling capacitor within the sampling interval. Figure 7 also shows the dimensions of the capacitances as seen from the analog input. The capacitances consist of stray-capacitances and the actual sample capacitance. These capacitances must be charged within 4 machine cycles (machine cycle '2' until '5'), which will put a constraint on the maximum source resistance. Example: An input signal with a slope of 10V/ms applied to the ADC input. For simplicity, assume that the capacitance that must be charged via $R_{\rm S}$ is 14pF and the 80C552 is running on 30MHz. At this frequency, the available charging time for the capacitor is 1.6 $\mu$ s. With the given slew-rate and the charging time of the capacitor, the analog voltage $V_{\rm IN}$ has changed 16mV. The response of an RC-network on an input ramp signal is: $$A \bigg\lceil t - RC \bigg( 1 - e^{-\frac{t}{RC}} \bigg) \bigg\rceil$$ A is slew-rate of input signal; RC is time constant of input RC-network. The term: $$ARC\left(1 - e^{-\frac{t}{RC}}\right)$$ represents the deviation of the capacitor voltage from VIN. If this deviation must be less than $^{1}/_{2}LSB$ (is 2.5mV at $V_{REF}=5.12V)$ after 1.6µs, then the RC-time must be less than 0.25µs. Given that $R_{S}=2.5\kappa\Omega$ and C = 124pF, the RC time of the input circuit of the 8XC552 is 35ns. Hence, there will be no significant error contribution because of the charging time of the input capacitance. The two constraints on $R_S$ mentioned above show that the effect of the input leakage current determines the maximum value for $R_S$ . Conclusion: Rs should not exceed 2.5kΩ. #### EIE/AN93017 #### 3.2 Layout Considerations Although this application note handles subjects related to the ADC, the following layout considerations are also valid for applications that do not use the ADC. For more general information on PCB layout design, see Reference 5. #### 3.2.1 Decoupling The analog and digital circuit parts in the 80C552 have their own set of power supply pins. Mutual inductance between on-chip $AV_{DD}$ and $AV_{SS}$ signal lines will cause the analog AC current $I_A$ to flow in the $AV_{DD}$ and out of the $AV_{SS}$ pin. The same is true for the digital AC current $I_D$ in the $V_{DD}$ and $V_{SS}$ pins (Figure 8). Because this mutual inductance is harder to realize off-chip, a low-impedance signal path must be created for both $I_A$ and $I_D$ . This is realized with decoupling capacitors between $AV_{DD}$ and $AV_{SS}$ for the analog signal part; a decoupling capacitor between $V_{DD}$ and $V_{SS}$ will decouple the digital signal part. To ensure a low impedance ground path, the use of a ground plane is recommended. The decoupling capacitors (for example, 100nF ceramic capacitors) must be placed as close as possible to the $AV_{DD}$ and $V_{DD}$ to minimize the loop area of the supply currents. Series inductors in the power supply lines may be used to improve decoupling (for example, 1..5µH). Using this decoupling scheme, both analog and digital supply connections can be connected together to a single (stable) +5V. Figure 8. 734 1994 Jun 28 Philips Semiconductors Application note # Using the analog-to-digital converter of the 8XC552 microcontroller ## EIE/AN93017 #### 3.2.2 Grounding When using both analog and digital circuits on the same PCB, it is common practice to isolate the analog power supply and ground as much as possible from the digital power supply and ground. This will reduce crosstalk via common ground impedances. Common impedances may result in noise in the (sensitive) analog circuitry caused by crosstalk of noise that originates from the digital circuitry. At some point however, both analog and digital grounds must be tied together. When this takes place far from the microcontroller, it will increase impedance between the analog and digital ground connections. This can create a considerable differential voltage between the analog and digital ground lines. Analog and digital circuitry inside the microcontroller will operate at different ground levels and improper functioning may be the result. A second effect of large ground impedance is that the crosstalk between the analog and digital circuits does not take place via the common ground impedance anymore, but via internal parasitic capacitances and substrate contacts. To prevent differences in ground levels, the analog and digital ground inside the 80C552 are connected together via an impedance of $\pm 2\Omega$ (Figure 8). This will keep both grounds at the same DC level. This impedance does not mean that now a common ground pin for analog and digital ground currents can be used. Impedance of the common bondwire will cause ground bounce, and thus crosstalk between digital and analog circuits. When the supply lines are properly decoupled, mutual inductance between the on-chip supply traces will assure that the AC-part of the supply current that flows inside $AV_{DD}$ and $V_{DD}$ will leave via the AV-ss and Vss pin even though AV-ss and Vss are connected together via a $2\Omega$ impedance. The best place on the PCB to connect AV-ss and Vss to each other is directly outside the microcontroller. This is also the best place for the ground connection of the decoupling capacitors. If the ground connection is to a ground plane, a ground plane on the component side is preferred. Two separate grounds are needed if the application has more analog ICs on the PCB, apart from the 80C552. In that case, the AVss and Vss of the 80C552 should be connected to the analog ground. The digital ground may be the return path for, for instance, line drivers. This will result in a ground that is less 'clean' than the analog ground. For the digital circuits this less 'clean' ground is less of a problem because they always have a certain noise margin. An alternative is to create a 'star-point'. This is a connection between AVss and Vss at the ADC area of the 80C552. Care should be taken to avoid ground loops in the other circuit parts up to the power supply. If the 80C552 application also uses external digital circuits, noise margin may be lost due to possible different ground levels. This can be reduced by the connecting two anti-parallel diodes close to the ground pins of the 80C552 and the connected digital circuits (Figure 9). Figure 9. 735 EIE/AN93017 #### 3.2.3 Placement of External Components External circuits connected to the microcontroller should be p;aced as close as possible to the microcontroller. This will reduce signal loops and common impedances on which high frequent signals may occur. These signals may come from an external source or may be generated by the microcontroller itself. When the disturbing signals are coming from an external source, they may cause improper functioning of the microcontroller. If originating from the microcontroller, they will cause unwanted radiation. When a common ground plane cannot be implemented, the microcontroller and circuits directly connected to the 80C552 must have a local groundplane (Figure 10). This local ground should have a connection to the main ground of the application at some point. If, for layout reasons, it is not possible to place the external circuitry close the the microcontroller, an RC-filter may be placed between the microcontroller and the external circuit (Figure 10). When microcontroller lines are connected to Off-PCB circuits, it is also advised to connect an RC network to the I/O line. The reason is sensitivity of the microcontroller to short (4 . . 5ns) high-voltage (30 . . 40V) spikes. Although these pulses will not damage the microcontroller, they may be responsible for incorrect functioning. With microcontrollers becoming faster, the on-chip I/O drivers will have increased bandwidths, hence become more sensitive for short spikes. The resistor of the filter should be connected as close as possible to the output of the driving device. The capacitor of the filter should be connected as close as possible to the input of the receiving device. Also the ground connection of the capacitor must be connected as close as possible to the ground of the receiving device. Values of the resistor of the filter depend on the drive capability of the outputs and the input impedances/levels of the inputs connected to the filter. The series resistor will reduce some noise margin. Typical capacitor values are 470pF. When connected to 80C552 inputs, the resistor value may be 1k; for 80C552 outputs $100\Omega$ may be used. NO (filter)-capacitors should be connected directly to outputs! This will cause (dis)charge currents to flow in the supply and ground lines. This can cause severe noise problems in the application. Figure 10. 736 1994 Jun 28 Philips Semiconductors Application note # Using the analog-to-digital converter of the 8XC552 microcontroller #### EIE/AN93017 #### 4.0 PROGRAM EXAMPLES Two program examples are given that show how to operate the ADC with software. The sources are written in 'C'. The program 'ADC\_pol.c' works on polling basis; the program 'ADC\_int.c' works on interrupts. The programs will start scanning all ADC inputs when a rising edge appears on the STADC pin. This can be realized with a resistor from ground to STADC and a switch from STADC to V<sub>DD</sub>. If STADC is connected to P4.0, a conversion of all channels will start every 1.14ms. Timer T2 controls the timing of P4.0. When all analog input signals on P5 are converted, the results will be sent to the UART and be made visible on a terminal. The communication part of the program is given in the file 'output.c'. After compiling and assembling 'output.c', it should be linked to 'ADC\_pol' or 'ADC\_int'. The required terminal settings are: - 8 data bits - no parity - 1 STOP-bit - 19200 baud. The 80C552 must run on 11.0592MHz. The following points are important when writing code for the ADC: ADCS and ADCI must be cleared, before programming AADC0..AADR2. - Channel selection bits AADR0..AADR2 must be programmed before setting ADCS (software start) or ADEX (enabling hardware start) - When working in polling mode, use ADCI to test if the conversion is finished. - Do not test 'ADCS=0' for this purpose. - When and ADC conversion is initiated by software, there is a delay of 2 machine cycles between the moment of writing a '1' to ADCS and reading a '1' from the ADCS-bit in ADCON. - When an ADC conversion must be initiated by a rising edge on ADEX, it is not known when ADCS becomes '1'. This depends on the external signal that starts the conversion. The following development tools were used on a PC (DOS 5.0): | TOOL | TYPE | PHILIPS NUMBER | |------------|--------------------------|-------------------------------| | C-compiler | BSO/Tasking V2.1 | OM4136 | | Assembler | BSO/Tasking V3.3 | OM4142 | | Emulator | SDS+80C552 probe | OM4120S<br>+OM1092<br>+OM1095 | | Debugger | BSO/Tasking XRAY51 V1.4d | OM4129 | #### ADC\_pol.c ``` *0* MODULE : adc_pol.c *0* FILENAME : adc_pol.c *** *0* APPLICAITON : Demo code for ADC of 8xC552 polling *0* mode *** *0* PROGRAMMER : T. v. Daele *** *0* DESCRIPTION : After rising edge on STADC-pin, all *0* ADC channels are scanned. *0* Rising edges are available on P4.7 at a *0* repetition rate of 1.14ms. This timing is *0* controlled by T2. *0* Results are sent to UART. #define ADEX 0 \times 20 #define ADCI 0x10 #define ADCS 0x08 void write_UART (unsigned int *, unsigned int); ``` ## EIE/AN93017 ``` void main(void) unsigned int conversion, result_ADC[8]; unsigned char ADC_Channel; SOCON=0x40; /* 8 bits, no parity, 1 STOPbit */ TH1+TL1+0xfd: /* 19200 Baud @11.0592MHz */ PCON=0x80; TMOD=0\times20; TR1=1; TM2CON=0x0d; /* Source T2: osc/96 */ RTE=0x80; /* Overflow rate: 0.569ms P4.7 toggles every 0.569ms ADC conversion on rising edge STADC P4.7/STADC: 1.14ms conversion rate conversion=0; while(1) for (ADC_Channel=0;ADC_Channel<*);ADC_Channel++)</pre> ADCON=0; /* Make sure ADCI and ADCS are cleared ADCON=ADC_Channel; /* before ADC channel is selected */ if (ADC_Channel==0) ADCON=ADEX; /* ADC0: External start */ else ADCON+ADCON | ADCS; /* ADC1..ADC7: Software start */ while((ADCON&ADCI) == 0); /* Wait till conversion finished by checking ADCI */ result_ADC[ADC_Channel]=5*((256*ADCH+(ADCON&0xc0))>>6); /* Calculate 10-bits binary result relative to 5.12V ref */ write_UART(&result_ADC,conversion++); /*Output results to UART */ if (conversion==10000) conversion=0; } ``` ### **EIE/AN93017** #### ADC\_int.c ``` *** : adc_int.c *0* MODULE *** *0* : adc_int.c FILENAME *** *0* APPLICATION : Demo code for ADC of 8xC552 in interrupt *0* mode *** : T. v. Daele *0* PROGRAMMER *** *0* : After rising edge on STADC-pin, all DESCRIPTION *0* ADC channels are scanned. Rising edges are available on P4.7 at a *0* *0* repetition rate of 1.14ms. This timing is *0* controlled by T2. *0* Results are sent to UART. *** ***************** #define ADEX 0x20 #define ADCI 0x10 #define ADCS 0x08 #define ADCIn 0xref #define FALSE #define TRUE void write_UART(unsigned int *, unsigned int); bit conversion_finished; void main(void) unsigned int conversion, result_ADC[8]; unsigned char ADC_channel; /* 8 bits, no parity, 1 STOPbit */ SOCON=0x40; /* 19200 Baud @11.0592MHz */ TH1=TL1=0xfd; PCON=0x80; TMOD=0x20; TR1=1; TM2CON=0x0d; /* Source T2; osc/96 */ RTE=0x80; /* Overflow rate: 0.569ms P4.7 toggles every 0.569ms ADC conversion on rising edge STQADC P4.7/STADC: 1.14ms conversion rate EAD=1; /* Enable ADC interrupt */ EA=1: conversion_finished=FALSE; ADC_channel=conversion=0; ADCON=0; /* First conversion; external start */ ADCON=ADEX: while(1) if (conversion_finished==FALSE) /* User code executed while conversion is in progress */ ``` **EIE/AN93017** ``` else result_ADC[ADC_channel]=5*((256*ADCH+(ADCON&0xc0))>>6); /* Store result */ if (ADC_channel!=7) /* Prepare conversion of next channel */ ADCON=++ADC_channel; ADCON+ADCON ADCS; } else /* ADCO..ADC7 is converted. Send results to UART */ write_UART(&result_ADC,conversion++); if (conversion==10000) conversion=0; ADC_channel=0; ADCON=0; /* Prepare next scan */ ADCON=ADEX; conversion_finished=FALSE; } } } interrupt 10 using 1 void ADC(void) ADCON=ADCON&ADCIn; /* Clear ADCI flag */ conversion_finished=TRUE; ``` **EIE/AN93017** #### output.c ``` *** *0* MODULE : output.c *** *0* FILENAME : output.c *0* APPLICATION : Example program for 80C552 ADC *** *0* PROGRAMMER : T. van Daele *** *0* DESCRIPTION : The results of the conversion are written *0* to the 80C552 UART. *** *0* FUNCTIONS : <name> <description> *0* write_UART entry point *0* send_byte trx byte *0* trx binary nibble decode *0* send_bin_byte trx binary byte *0* send_dec_int trx decimal integer *0* send_string trx aSCII string ************************* rom char string_0[] = "Conversion #"; rom char string_1[] = ": (Ref is 5.12V)"; rom char string_2[] rom char string_2[] = "ADC_Channel # "; rom char string_3[] = rom char string_4[] = "mV"; ": "; "\r\n"; rom char new_line[] *** *1* FUNCTION : send_byte *** *2* SYNOPSYS : send_byte(src_byte) *** *3* ARGUMENTS : type name *3* src_byte char *** *4* RETURNS : nothing *5* MODIFIES : nothing *** *6* : Send byte to terminal via UART DESCRIPTION *6* Wait till transmission is finished *** *7* HISTORY : data who description *7* 05-02-93 initial tvd void send_byte(char src_byte) SOBUF = src_byte; /* Byte to transmit */ while (TI == 0); /* Wait till byte is transmitted */ TI = 0; /* Clear transmit flag */ ``` ## **EIE/AN93017** ``` *** *1* FUNCTION : decode *2* SYNOPSYS : decode(char src_nibble) *** *3* ARGUMENTS : type name *3* char src_nibble *** *4* RETURNS : nothing *** *5* MODIFIES : nothing *** *6* DESCRIPTION : Decode least significant nibble to *6* ASCII and transmit *** *7* HISTORY : data who description *7* 05-02-93 tvd initial *** void decode(char src_nibble) if ( src_nibble < 0x0a) send_byte(src_nibble + 0x30); else send_byte(src_nibble + 0x41 - 0x0a); } *** *1* FUNCTION : send_bin_byte *** *2* SYNOPSYS : send_bin_byte(char src_byte) *** *3* ARGUMENTS : type name *3* char src_byte *** *4* RETURNS : nothing *** *5* MODIFIES : nothing *** *6* DESCRIPTION : Split a binary byte in nibbles, decode *6* to ASCII and transmit *** *7* HISTORY : data who description *7* 05-02-93 tvd initial *** void send_bin_byte(char src_byte) ``` ## EIE/AN93017 ``` *** *1* FUNCTION : send_dec_int *2* SYNOPSYS : send_dec_int(unsigned int src_wrd) *** *3* ARGUMENTS : type name *3* unsigned src wrd *** *4* RETURNS : nothing *** *5* MODIFIES : nothing *** *6* DESCRIPTION : Decode binary integer to decimal and *6* transmit *** *7* HISTORY : data who description *7* 07-07-93 tvd initial *** void send_dec_int(unsigned int src_wrd) { unsigned char a,b,c,d,e; a=src_wrd/1000; /* a='thousands' */ b=((src_wrd%1000)/100); /* b='hundreds' */ /* c='tens' */ c=((src_wrd%100)/10; /* d='units' */ d=src_wrd%10; e=16*c+d; /* Print value for tens and units */ /* Print integer without leading zero's */ send_byte(0x20); if (b==0) { send_byte(0x20); if (c==0) { send_byte(0x20); decode(d); } else send_bin_byte(e); } else { decode(b); send_bin_byte(e); } else send_bin_byte((16*a)+b); send_bin_byte(e); } ``` ## EIE/AN93017 ``` ************ *** *1* FUNCTION : send_string *** *2* SYNOPSYS : send_string(rom char *str_ptr) *** *3* ARGUMENTS name : type *3* rom char * str_ptr *** *4* : nothing RETURNS *** *5* MODIFIES : nothing *** *6* DESCRIPTION : Send a string of characters from ROM to *6* terminal. *** *7* HISTORY : data who description *7* 05-02-93 tvd initial ************************* void send_string(rom char *str_ptr) while (*str_ptr != 0) /* Send byte */ send_byte(*(str_ptr++)); } *** *1* FUNCTION : write_UART *** : write_UART(unsigned int *ADC_result, *2* SYNOPSYS *** unsigned int conversion_cnt) *** *3* ARGUMENTS : type name *3* unsigned int * src_ptr *3* unsigned int msg_ptr *** *4* RETURNS : nothing *** *5* MODIFIES : nothing *** *6* DESCRIPTION : Decode results to correct format and send *6* to UART *** *7* HISTORY : data who description *7* 30-06-93 tvd initial *** void write_UART(unsigned int *result_ptr, unsigned int conversion_cnt) unsigned char cnt; send_string(new_line); send_string(new_line); /* Send message number */ send_string(string_0); send_dec_int(conversion_cnt); send_string(string_1); for (cnt=0;cnt<8;cnt++) { send_string(new_line); send_string(string_2); decode(cnt); /* Send channel number */ send_string(string_4); send_dec_int(*(result_ptr++)); /* Send result to UART */ send_string(string_3); ``` ## Chips push CAN bus into embedded world ## This week: Special Report Surface-mount technology gets bigger as packages get smaller # Electronic Engineering TIVES Monday August 24, 1992 Issue 707 A CMP Publication #### THE INDUSTRY NEWSPAPER FOR ENGINEERS AND TECHNICAL MANAGEMENT ## Chips push CAN bus into embedded world Sunnyvale, Calif. — The Controller Area Network (CAN) serial bus is being thrust into a key role in embedded systems, boosted by a series of recent silicon announcements. Delta-t GmbH, Intel Corp., Motorola Semiconductor and Philips/Signetics Co. have all prepared new chips that should slash the cost of a CAN bus connection, increase bus functionality and accelerate the bus's migration from a little-known automotive standard to a widely used industrial interconnect scheme. Developed by Intel with Robert Bosch GmbH in the mid-1980s to solve cabling and control problems in vehicles, the CAN bus combines an inexpensive, one-wire or two-wire medium with multimaster, error-correcting protocol and very high resistance to electromagnetic interference. Unlike most multi-master buses, however, CAN also guarantees a maximum latency, often in the neighborhood of 1 ms, for high-priority messages while making room for lower-priority traffic as well. Thus, although the bus was originally conceived as a way to reduce the literally miles of wire in a modern automobile, it is in many ways ideally suited for a wide range of industrial control applications as well. #### General-purpose bus CAN has since emerged as a generalpurpose sensor/actuator bus system for distributed real-time control applications that extend beyond the automotive realm. "CAN was spotted by the industry as a very promising field-bus technology in the area of industrial automation," said Tom Suters, systems architect at Philips Medical Systems, in Da Best, the Netherlands. "We are beginning to see CAN as a widely used standard in trucks and farm equipment, industrial automation and even some medical equipment," agreed Signetics marketing manager Mike Thomson. But CAN's opponents have often criticized its high implementation cost as well as the lack of controller chips and supporting tools. Proponents have argued that volume production for the automotive market would inevitably bring down the silicon prices, but that has yet to happen. Now vendors are pointing to a new generation of low-cost or highly integrated controllers as the solution. Motorola is sampling a controller, dubbed the 68HC705X4, that will be supported by an evaluation board and an emulator. Other implementations based on the 68HC11 and the 68HC16/683XX are in the pipeline. Intel Corp., working in conjunction with design partner Bosch, has sampled a next-generation CAN chip, the 82527, that offers support for two sizes of message indentifiers—11 bit and 29 bit—as specified in CAN Spec. 2.0, released in September. Craig Szydlowski, product marketing engineer for CAN at Intel, said the original CAN 1.2 standard allowed for only 11-bit message indentifiers. Supporters of 11850—the competing automotive bus favored by the Society of Automotive Engineers—fought for an optional larger message field so 1850-style 27-bit commands could be easily mapped into CAN protocols. "This gives CAN the ability to broadcast commands using what had been essentially an address field," explained Signetics' Thomson. "For example, a CPU might send out a command telling all of the lamps in a vehicle to test themselves for conductivity and report any burn-outs." The new format does not imply that CAN and J1850 physical buses can be easily interfaced, Szydlowski emphasized, only that the message structure would be similar. #### Just the next step The Intel chip "looks like a smart RAM." Szydlowski said, with RAM space on-chip to store 14 8-byte receive/transmit message objects (with a fifteenth area for received message objects). The message objects are stored at fixed RAM locations. One on-chip filter is dedicated to the receive message object, with a global acceptance filter mask used for the other 14 message objects. Intel's new chip is merely the next step in integration, to be followed by efforts to embed 527 functionality into a standard Intel 16-bit controller architecture. Philips/Signetics has added to its product line as well but but from a different direction. The company has integrated a CAN bus controller into a heavily configured 8051-type MCU to come out with the 8XC592. The chip combines large ROM and RAM space with five 8-bit I/O ports, a 10-bit A/D, two 8-bit-resolution PWM outputs, and the usual counter/timers and UART. The announcement puts Philips and Intel in a confrontation over processing power. Intel will pursue a strategy of integrating CAN controllers into 16-bit MCUs and driving up node performance. The Dutch giant is going in the opposite direction, starting with a high-end commodity 8-bit part and heading downward in cost. "Customers will want a part for a real simple node, without even a CPU on it," claimed Thomson. "You don't hang an 8051 on a light bulb. We are working on a controller solution for under \$1." Philips has also announced a high-speed CAN transceiver that can be hooked directly to its controllers. The IX controller from Delta-I GmbH, meanwhile, should prove useful to manufacturers of sub-systems for multiprotocol environments when it debuts sometime next year. The protocol used for each application will be able to be programmed into a flash-memory section of the controller. The design activity promises to both lower the cost of a simple CAN-bus node and increase the computing power that can be integrated into an expensive node. Both moves should expand the market deeper into industrial control and instrumentation applications, although CAN partisans see little hope of displacing J1850 from the big three domestic makers. CAN is a multimaster bus topology network that connects several stations. An International Standards Organization draft from 1990 specifies the first two layers of the Open Systems Interconnect (OSI) model: the physical layer and the data-link layer. Philips Medical Systems developed an application layer, using CAN to control X-ray diagnostic systems, control real-time image acquisition and connect user-interface devices. Today, the three layers together form the CAN Reference Model. -Addtional reporting by Ron Wilson Handling CAN-controller complexity has been a barrier to acceptance for this control-oriented bus. ## Chips push CAN bus into embedded world NFWS # Controller Area Network (CAN) Products From Philips Semiconductors **8XC592 CAN Microcontroller** - The 8XC592 is a stand-alone high-performance microcontroller based on the 80C51 architecture. Its on-chip CAN interface makes it ideal for applications with a harsh, noisy environment. #### The 8XC592 Features include: - 16K x 8 EPROM (87C592) - 16K x 8 ROM (83C592) - ROMless (80C592) - 512 x 8 RAM, expandable externally to 64k bytes - Three Standard 16-bit timer/counters - A 10-bit ADC with 8 Multiplexed Analog Inputs - Two 8-bit Resolution, Pulse Width Modulation Outputs - Five 8-bit I/O Ports Plus One 8-bit Input Port Shared with Analog Inputs - CAN Controller with DMA Transfer between Internal Data RAM and CAN Registers - Standard 80C51 UART - On-Chip Watchdog Timer **82C200 CAN Interface** - The 82C200 is a highly integrated stand-alone controller for CAN. The 82C200 with a simple bus line connection performs all the functions of the physical and data-link layers. The application layer of an electronic control unit (ECU) is provided by a microcontroller, to which the 82C200 provides versatile interface. #### The 82C200 Features include: - Multi-Master Architecture - Interfaces with a Large Variety of Microcontrollers - 2032 Message Identifiers - Powerful Error Handling Capability - · Configurable Bus Interface **82C150 Serial Linked I/O CAN Interface** - The 82C150 Serial Linked I/O CAN is a single-chip 16-bit I/O device with an on-chip CAN-controller. 82C150 is a very cost-effective way of increasing the I/O-capability of a microcontroller as well as reducing the amount and complexity of wiring. Advanced safety provided by the CAN protocol combined with low-cost makes the 82C150 a very attractive product for a wide variety of applications. #### The 82C150 Features include: - Single-Chip I/O Device with CAN Protocol Controller - 16 Configurable Digital or Analog I/O Ports - Each Port Individually Configurable via the CAN bus - 10-bit A/D converter with up to 6 Multiplexed Inputs - · Bit Rate 20 kbit/sec to 125 kbit/sec August 1992 746 # THE COMPUTER **APPLICATIONS JOURNAL** **MEASUREMENT** & CONTROL SPECIAL SECTION: Embedded Graphics & Video **Time Domain Reflectometer Overlay Text on Video** October/November, 1992 — Issue #29 # Add Text Overlay to Any Video Display All the latest VCRs have on-screen programming in an effort to simplify the notorious task. Now you can have your HCS II or any other computer send you messages while you're watching your favorite TV show. # SPECIAL SECTION **Bill Houghton** uppose, for the moment, you've built and installed the HCS II home control system described primarily in issues 25 and 26 (February/March and April/ May '92) of the Computer Applications Journal. In issue 27 (June/July '92), Ed Nisley described an add-on LCD output device as a way to obtain information about the status of the system and its various nodes. It's a nice addition to the network, but useful only when you're near to the display module. What do you do if you're across the room watching TV settled into your favorite armchair? You could get up and venture across the room. Or, if you build the interface described in this article, you could hit a button on your HCS II IR remote and see network information displayed on your TV set overlaid onto the program you are watching. This article describes an On-Screen Display (OSD) terminal for HCS II (we'll call it "TV-Link" to match the other HCS II modules) that allows color text characters to be displayed on top of a background color video signal. The terminal is built around the Philips/Signetics 87C054 OSD microcontroller. #### **FEATURES OF 87C054** The 87C054 is an 80C51-based microcontroller designed to provide an advanced OSD for TV and video applications. It can produce characters in eight foreground and eight background colors. In addition, the background color can be removed, showing through the original video. It also has nine pulse-width modulator outputs for controlling analog functions. Similar to a standard 80C51, it has 28 digital I/O pins, two external interrupts, and two timer/counters. RAM and ROM spaces on the 87C054 are larger than the 80C51: 192 bytes of RAM and 16K bytes of EPROM. (The OSD has additional RAM and EPROM areas that are not part of the normal 80C51 memory map.) One unique feature of the 87C054 is what Signetics describes as a "soft- Photo 1—The TV-Link can be used by your computer to overlay messages on any video signal. Figure 1—Converting from RGB to NTSC involves modulating and adding difference signals. ware ADC." This ADC consists of an internal 4-bit DAC that feeds one input of a comparator. The other comparator input can be connected to one of four I/O pins. The output of the comparator is tied to a status bit in a register that is testable by software. A TV set often uses this logic for measuring the AGC voltage during tuning. A real-time clock and other low-precision analog measurements can also use it as a zero-crossing detector. The OSD of the 87C054 consists of a 128-character RAM array (OSD-RAM), a 64-character font EPROM, a video clock oscillator, and the OSD logic. The OSD logic accepts horizontal sync (HSYNC) and vertical sync (VSYNC) signals and provides three digital video outputs for character information. In the datasheet for this part, these outputs are called VIDO, VID1, and VID2, but they can also (and perhaps better) be thought of as RED, GREEN, and BLUE. A multiplexer control output is also present to indicate when to display character data or original video information. The video clock oscillator provides timing for the character dots. In most applications, this oscillator is simply an LC tank circuit connected to the VCLK pins. The frequency controls the character width. One nice feature is that the video clock is killed at the leading edge of HSYNC and restarted at the trailing edge of HSYNC, which causes the video clock to start in the same phase on every line, ensuring the dots align vertically from one scan line to the next. The character font stores the binary pattern for the individual characters. Characters are 14 dots wide and 18 scan lines high. The OSDRAM stores the characters to be displayed on the screen along with certain attribute data pertaining to those characters. Once a character has been written to the OSD, no further CPU intervention is required to "refresh" the screen. Many OSD architectures have been developed over the years for use in the consumer television market. Almost all of them have required fixed character row formats, limiting the designer's flexibility in designing video menus and screens. The 87C054 was designed to avoid such constraints, and there are no architectural limits on the number of characters in a row of text or the number of rows of text to a screen. (There are physical limits imposed by the dot clock frequency and the scan rate, of course.) The HSTART and VSTART parameters in the OSORG (on-screen origin) register define the intial position of the start of the OSD. Once the initial vertical and horizontal positions have been found, the 87C054 will "fetch" characters from the OSDRAM and place them sequentially on the screen. In order to have multiple rows of text, a special character has been defined and is referred to as NEWLINE. The NEWLINE character is much like a carriage return/line feed sequence on a computer in that it terminates the current row of characters and starts a new row of text. One advantage of this architecture is that it eliminates the need to pad display memory with space characters. The fetching and painting of rows of text will continue until either a new vertical sync pulse is detected or until an END attribute is fetched along with a NEWLINE character. #### NOW FOR THE DETAILS... Now that you understand the concepts of an OSD operation and the capabilities of the 87C054, focus your attention on the details required to overlay characters onto live video. The 87C054 OSD has a multiplexer output for switching video sources. Simply switching between the input video signal and the OSD character data would be nice. Unfortunately, you can't because the input video (from our home entertainment center) is in NTSC format and the character data is in RGB format. (Keep in mind that the goal is to input live video, add on-screen text, and present the result as a video signal at the output of our circuit.) One solution is to decode the input video into separate red, green, blue, *HSYNC*, and *VSYNC* signals. Then you could perform the multiplexing between video information and character data in RGB format. The resultant signals could then be encoded back into baseband video. If there were other reasons for the conversion into RGB, such a conversion Figure 2—A typical line of NTSC video consists of an initial horizontal sync pulse, followed by a short color burst signal, then the actual picture information. Figure 3—At the core of the TV-Link is the Signetics 87C054 microcontroller. The unit supports both RS-232 and RS-485 communications with a host computer. would be the way to go. However, the process of converting to RGB and then converting back to video introduces some distortion that could be visible on the screen. Another solution is to find a way to encode the RGB data from the OSD microcontroller into video. Then you can simply switch between the two sources. Sound simple? The situation gets a little more complex when you consider the issues of making the characters appear with the proper color in NTSC. Reviewing how color is encoded in NTSC is in order. #### **COLOR TELEVISION** When you first look at video, you often wonder why in the world it was done the way it was. A long time ago, before Americans had ever heard the names of Japanese TV makers, RCA research labs were developing color televeision. One of the requirements imposed on designers by the FCC was that the broadcast signal needed to be compatible with existing black-and-white TV sets and had to be contained within the same bandwidth as a B/W signal. Such requirements meant that some component of the signal had to contain overall brightness information, which is the main reason why they could not simply transmit separate R, G, and B channels within the video bandwidth allowed. To make a very long story short, the engineers involved decided that the scene brightness (which they called "Y" or luminance) could be described by the relationship Y = 0.59G + 0.3R + 0.11B Someone observed that if they took two copies of the luminance signal and subtracted one copy from one of the colors (say, RED) and did the same with a different color (say, BLUE), the result would be two signals that contained all of the information needed to represent color. These resultant signals, R-Y and B-Y, are the color difference signals. Now that you have two signals, how can they be transmitted on one RF carrier? The answer they came up with was to modulate one of the signals (B-Y) with an RF carrier. The Figure 4a—The JRC2244 switches between the incoming video signal and the on-screen characters under control of the 87C054 MCU. Figure 4b—The TDA4820T sync separator provides the processor with horizontal and vertical sync signals other signal (R-Y) was to be modulated with the same RF carrier, but the carrier would be shifted by 90°. When the outputs of the two modulators are added together, the result is the *vector sum* of the two signals, containing both an amplitude and a direction [phase angle]. See Figure 1. We now have a single signal that contains all of the color information. The TV receiver needs just one more piece of information to demodulate this signal. It needs a reference for the carrier used for the modulation, that is, the receiver needs to know where 0° of the color carrier is (in video, this color carrier is referred to as the chroma subcarrier). In order to give this reference to the receiver, a small number, or "burst," of cycles of the color subcarrier (hence, the term color burst) are transmitted on the back porch of the horizontal sync pulse. In most NTSC systems, this chroma subcarrier has a frequency of approximately 3.58 MHz. A typical line of color NTSC video is shown in Figure 2 In order to convert the character data from the OSD into NTSC, you will need to sum the data into R-Y and B-Y components. Then you will need to modulate these components with a chroma subcarrier at 0° for B-Y and +90° for R-Y. One more item to consider. If you have an output video signal composed of a video source with characters overlaid onto it, the chroma subcarrier reference (i.e., color burst) present on the output video signal is the color burst provided in the original input video. In order for the receiver/monitor to interpret the color of the OSD characters correctly, the chroma subcarrier used to modulated the OSD's R-Y and B-Y components must have exactly the same frequency and phase as the color burst on the original video input signal. Once you get the OSD information in the form just described, you can switch between this "OSD video" and the original input video to produce the final output. ## THE TV-LINK HARDWARE SOLUTION Figure 3 shows a block diagram of the TV-Link, while Figure 4 shows the schematic. Referring to the schematic, the original input video connects to J2 and is AC coupled into buffer amplifier, Q1. This amplifier provides load isolation between the video signal source and the circuits on the TV-Link board. JP4 is a jumper allowing for a 75-ohm termination resistor to be connected to J2. The output of the Q1 buffer amplifier feeds the sync separator, the video switch, and the chroma subcarrier regenerator circuits. #### SYNC SEPARATION The sync separator consists of U6, a TDA4820T Philips sync separator. The video signal is coupled into the TDA4820T through capacitor C14, where it is amplified with a gain of 15. The black level clamping voltage is stored in capacitor C14. From the stored black level voltage and the peak sync voltage, the 50% value of the peak sync voltage is generated and stored in capacitor C15. A slicing level control circuit ensures a constant 50% peak sync value regardless of the picture content amplitude provided the sync pulse amplitude is between 50 mV and 500 mV. A comparator in the composite sync slicing stage compares the amplified video signal with the DC voltage derived from the 50% peak sync voltage, producing the composite sync output. Vertical slicing circuits compare the composite sync signal with a DC level equal to 40% of the peak sync signal, producing the vertical sync output. The reduced vertical slicing level ensures more energy for the vertical pulse integration. The slope is double integrated to eliminate the effects of interference caused by noise or line reflections. The value of resistor R10 sets the vertical integration delay time. The outputs of the sync separator are positive-going signals with peak amplitudes exceeding 10 V. Resistor pairs R11/R12 and R13/R14 serve as voltage dividers for the VSYNC and CSYNC outputs, respectively. An LM339 comparator, U5, serves as an inverter for the sync signals because the modulator circuits require active low sync signals. There is a great tendency with video circuits to make the coupling capacitors very large to pass the low- Figure 4c—In order to properly overlay colors onto a PAL signal, you must know whether you're on an odd or an even field, so extra circuitry must be included on the board to support PAL frequency sync components (60/50 Hz, typically) into low-impedance nodes. The TDA4820T has a moderately high input impedance on pin 2. Because the black level is stored in C14, the value of C14 should be kept close to 0.22 µF. #### THE 87C054 MCU WITH OSD The 87C054 microcontroller, U3, accepts composite sync and vertical sync signals from the sync separator and provides RGB digital outputs for character data. The multiplexer control output, VCTRL, connects to the video switch, U2, a JRC2244. Inductor L1 and capacitors C8 and C9 form a video clock oscillator that determines the width of a character font dot. The values of these components are not critical but are typically chosen such that a video dot width is equal to the spacing between scan lines. This oscillator is killed at the leading edge of the HSYNC signal and allowed to startup at the trailing edge. Such synchronization causes the oscillator to start at exactly the same point from one scan line to the next, causing character dots to appear in exactly the same spot on each line. In addition to the OSD functions, the 87C054 also performs network interfacing and protocol tasks. This microcontroller has plenty of performance bandwidth because the OSD logic is self-refreshing and independent of the MCU core. #### **VIDEO SIGNAL SWITCHING** The JRC2244 video switch, U2, contains three video inputs, two of which are used in this application. One of these inputs, VIN1, is capacitively coupled to the OSD video signal. This signal is the 87C054's RGB data after encoding into baseband video. The other input, VIN3, is capacitively coupled to the original video input signal. The JRC2244 provides internal bias sources to provide DC restoration to its video inputs. The JRC2244 accepts a switching control signal from the 87C054 and switches its output between the original video input and the OSD video signal. The video switch also has an internal 75-ohm line driver in its output stage. The JRC2244 has a moderate input impedance of about 15k ohms, allowing 10-µF coupling capacitors to be used. The output coupling capacitor is large because this signal can be used to drive 75-ohm loads. #### **RGB ENCODING** The LM1886, U13, and the LM1889, U14, encode the RGB data from the 87C054 into baseband video. The LM1886 has three DACs, one for each color. Each of these DACs has 3bit inputs, but because the 87C054 data is digital, the inputs to the LM1886 DACs are tied together yielding an output for each DAC that is either full-scale or zero. The outputs of the three DACs are internally summed to produce the luminance, R-Y, and B-Y amplitudes. The LM1889 accepts the regenerated chroma subcarrier, modulates the R-Y and B-Y signals, and produces baseband video on pin 13. Transistor Q5 is used as a buffer amplifier with voltage dividers R49 and R50 producing proper levels for the video switch. Note that the LM1889 accepts an external subcarrier signal at the junction of R46 and C52, but this subcarrier undergoes a phase shift caused by the resistor and capacitor networks associated with pins 1 Figure 4d—The CA3126 TV chroma processor is designed specifically for regenerating chroma subcarriers. and 18 of the LM1889. This phase shift will need to be considered when the subcarrier is regenerated. ## CHROMA SUBCARRIER REGENERATION The circuits that reproduce a chroma subcarrier in the same frequency and phase as the color burst consist of a high-pass filter, a sample-and-hold phase-locked loop (PLL), and a phase shift network and amplifier. The passive high-pass filter consists of inductors L4 and L5, resistor R28, and capacitors C25, C26, and C27. The filter starts passing signals at about 3.2 MHz, allowing the chroma subcarrier to pass through to the CA3126, U15. The CA3126 is a TV Chroma Processor IC designed specifically for regenerating chroma subcarriers. This IC contains a VCO and a PLL with sample-and-hold circuits in the error correction loop. As a result, the VCO-generated carrier is compared with the chroma signal from the high-pass filter during the time that color burst is present, indicated by the burst gate pulse (which I will describe later). The regenerated carrier output is present on pin 8 of the CA3126. Even though this carrier is phase locked to the color burst, it is not at exactly the same phase as the color burst. The nature of a PLL is such that the output will be locked but will always have some constant fixed phase delay relative to the input. Also, recall that the input circuits of the LM1889 added an additional constant phase shift to the injected carrier. The phase shift network and amplifier consisting of the Q3 and Q4 stages compensate for these fixed phase delays. This circuit provides an output whose phase is adjustable by means of variable capacitor C48, and has a tuning range of approximately 0° to 160° of phase shift. For a given input signal amplitude, the output signal amplitude is constant, regardless of the phase shift introduced. The output of this circuit is the signal injected into the LM1889 circuits. #### CONNECTING TO THE HCS II Now that you have a working terminal circuit for overlaying text onto live video, you still need to connect it to the HCS II network. In order to do this, you will need a serial interface compatible with the network, some software that handles network message formats, and software that interprets network messages and creates responses or actions (or both) to those HCS II network messages. This particular design includes both an RS-232 and an RS-485 interface. U1, a MAX232, provides the RS-232-to-TTL conversion for both the transmitter and receiver. U16, a 75176, provides the RS-485-to-TTL conversion. IP1 connects the receiver pin of the 87C054 to either the RS-232 or RS-485 interfaces. The transmitter pin of the 87C054 connects to both the RS-232 and RS-485 interfaces. One pin of the 87C054, P3.5, controls the driver enable of the 75176, allowing for selective talking on the HCS II network. JP3 provides for termination of the network. "But, wait a minute! The 87C054 doesn't have a UART," you say. True. There is no built-in UART on the 87C054 and the part does not have a transmitter pin or receiver pin. Figure 4e—Encoding the RGB data into baseband video is accomplished with an LM1886, which contains three DACs, and an LM1889, which accepts the regenerated chroma subcarrier, modulates the R-Y and B-Y signals, and produces baseband video. In this application, the serial data transmission and reception has been performed in software. The routine that handles serial transmission and reception was taken from the Signetics BBS ([800] 451-6644). It was originally designed for the 87C751 and had to be slightly modified to operate with one of the 87C054's timer/counters. The technique is often called "bit banging" and has the advantage of saving some hardware if you can afford the necessary time required of the software. ## NETWORK PROTOCOL PROCESSING As I indicated earlier, in addition to the serial interface software, you need code that handles network message formats. The code starts by waiting until either a "#" or an "!" is received, either of which indicates the start of a network message, then the entire message is stored in a buffer. Once the carriage return has been stored, the beginning character of the message is checked to see whether the message includes a checksum. If the message does not contain a checksum, the packet is assumed to be valid and the contents of the packet are processed. If a checksum is included, then the VERIFY routine is called to perform a checksum calculation on the packet. If the checksum matches, the packet is processed, otherwise, it is ignored and I return to waiting for the next network message. My original plans for handling network checksums included a checksum generator for sending network responses and a checksum checker for received messages. However, when I flowcharted the needs of both routines, I found that an awful lot of the logic was common to both. I went back and looked at the suggestions that Ed Nisley had provided for handling the checksums and understand now why he made those suggestions. My VERIFY routine's logic is based on Ed's previous work. The VERIFY routine performs two functions. First, it takes the checksum digits in the packet, converts them to binary numbers, and stores them in temporary variables. Next, the checksum digits are replaced with ASCII zeros and the checksum of the string is calculated. If the checksum matches, the error flag, CHKERR, is cleared, otherwise, it is set. The checksum that was calculated is converted to ASCII and stuffed into the checksum digits position, replacing the ASCII zeros. To prepare a string for transmission, all that is necessary is to stuff the message in the buffer with the checksum digits set to ASCII zeros and call the VERIFY routine. To check a message for correct checksum, simply call the VERIFY routine and check the CHKERR flag on return. Once the checksum verification (if required) has been performed, you still need to process the packet to see if it belongs to this terminal, and if it does, then you need to determine what action the network controller is asking you to take. The PROCESS routine first scans the packet, converting characters into upper case until the end of the packet has been reached. Next, the first character is examined to determine if the packet has checksums or not and a pointer is set to the NODEID position of the packet. The NODEID in the packet is compared with the NODEID variable. If there is no match, the packet is ignored and you wait for the next network message. If it does belong do this terminal, you can process the body of the network message. ## NETWORK COMMANDS AND SYNTAX The real essence of a network message is to carry a command from the network controller to the terminal or carry a response from the terminal back to the network controller. Table I shows the syntax of the commands available for operating the TV-Link terminal. These commands allow the HCS II Supervisory Controller to manipulate ports on the 87C054, format text for display, implement special built-in display functions such as color bars, and to read and write # Add Text Overlay to Any Video Display | A = string | Set HCS II network address to string | |----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Fx | Execute special function O Initialize screen 1 Display on 2 Display off 3 Display color bars 4 Wipe on 5 Wipe off | | Нху | Set Px.y high | | Lxy | Clear Px.y low | | Nn | Network response mode<br>N0 = normal network interface, no auto error or acknowledge responses<br>N1 = auto error and acknowledge response | | Px | Query port x 0 = Port 0 1 = Port 1 2 = Port 2 3 = Port 3 | | Px= nn | Write to port x where nn= two-digit hex value 0 = Port 0 1 = Port 1 2 = Port 2 3 = Port 3 | | Rx | Query register x; returns two-digit hex number 0 = OSDT (contents undefined) 1 = OSAT 2 = OSCON 3 = OSORG 4 = OSMOD 5 = Default char. attribute 6 = Default background space attr 7 = Default NEWLINE attribute | | Rx = nn | Write to register x; for use from outside of a string of text; writes to these registers from within a string; should use the \Wxnn command 0 = OSDT 1 = OSAT 2 = OSCON 3 = OSORG 4 = OSMOD 5 = Default char. attribute 6 = Default background space attr 7 = Default NEWLINE attribute | | S= string | String for OSD display; can include escape sequences for text formating, color, selection, etc. | | \Wxnn | Write to register x; for use within a string; functionally equiv. to the Rx = nn command | | Special cha | aracterss for use within a string of text | | \E<br>\B<br>\S<br>\N | End of Display at current position<br>Background Space<br>Split Background Space<br>NEWLINE | Table 1—The set of supported commands resembles that of most of the other HCS II network modules. OSD registers directly, giving full control of the OSD to the HCS II. #### CONCLUSIONS Developing this application was interesting and enjoyable. It also presented some challenges. The 87C054 proved well suited to this application in large part because of the 80C51 core and that the OSD is independent of the CPU. Once characters have been written to the OSD, you can forget the OSD until you want to change the display, and the CPU is free to pursue other tasks. The on-screen display and the microcontroller operations are primarily digital functions. The question of how to combine this technology with an analog video signal can be perplexing to most system designers whose professional experiences have been mostly digital circuits. One of the most perplexing issues during this project was how to re-create the chroma subcarrier. I knew that every color TV set had to perform this function, but finding out solutions took some searching before I discovered the CA3126. I'm hopeful you can profit from my experiences on this project. My thanks to Herb Kniess and George Ellis of Signetics for their help. Thanks also to Greg Goodhue from Signetics, who wrote the software-based UART code for the 87C751 that I modified for this project. Bill Houghton is an Applications Engineer at Signetics specializing in 80C51-based microcontrollers. #### SOFTWARE Software for this article is available from the Circuit Cellar BBS and on Software On Disk for this issue. Please see the end of "ConnecTime" in this issue for downloading and ordering information. #### SOURCES Requests for literature on Signetics/Philips microcontrollers including the "80C51-Based 8-Bit Microcontroller Data Handbook" may be directed to Sharon Baker at (408) 991-3518. Contact Bill Houghton at (408) 991-3560 with technical questions specific to the 87C054 and for information on the availability of a PC board and components for this project. © Circuit Cellar INK, The Computer Applications Journal. Reprinted by permission Issue #29 October/November, 1992 The Computer Applications Journal # **Philips Semiconductors** # **Section 9 Development Support Tools** Application Notes and Development Tools for 80C51 Microcontrollers #### **CONTENTS** | Development support tools | 759 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | Ashling CTS51 Microprocessor development systems for Philips microcontrollers | 766 | | BSO/Tasking: The total development solution for the 8051 family | 771 | | CEIBO DB-51 Development Board | 778 | | CEIBO DS-51 In-Circuit Emulator | 780 | | CEIBO DS-300 Peripheral Development Tools | 788 | | CEIBO DS-750 Microcontroller Development Tool | 790 | | CEIBO DS-752 Microcontroller Development Tool | 792 | | CEIBO EB-51 Emulation Board | 794 | | CEIBO MP-51 Programmer | 796 | | MetaLink iceMASTER-PE 8051 Family In-Circuit Emulator | 798 | | MetaLink iceMASTER 8051 Family In-Circuit Emulators | 803 | | NOHAU EMUL51-PC – PC-based in-circuit emulator | 816 | | PDS51 Development System for 8XC51 Microcontroller Derivatives | 827 | | LCP Programmers for 87C51 and Derivatives | 83 | | S87C00KSD 8XC51 and I <sup>2</sup> C Bus Evaluation Board | 834 | | OM4130 CAN evaluation board with the 8XC552 and 82C200 CAN controller | | | OM4239 CAN evaluation board with the 8XC592 microcontroller | 836 | | OM4240 Evaluation board for the 8XCE598 microcontroller | 83 | | OM4272 SLIO evaluation board with the 82C150 and 82C250 CAN ICs | | | OM4280 P83C852 Smart Card crypto-controller demonstration kit | | | Olivi4200 1 000002 Official Octobrillation Controlled C | 84 | # DEVELOPMENT SUPPORT TOOLS Philips Semiconductors manufactures support tools and also works closely with many "third-party" vendors who provide support tools for our wide variety of 80C51-based microcontroller derivatives. #### **Development Systems** In most cases, development systems are available in two versions for ROM and ROMless applications. The ROM emulation products are capable of supporting all versions of a given device type, including EPROM, ROM, and ROMless devices. In contrast, a ROMless emulator can only support applications designed for a ROMless microcontroller. Most development systems are designed to connect to an IBM-PC or compatible personal computer. #### **EPROM Programming Support** Philips Semiconductors works closely with major suppliers of EPROM programming equipment to support our family of EPROM microcontrollers. As a result, EPROM programming support is available within the programming facilities of many major distributors. The following is a list of vendors that offer support for Philips Semiconductors 80C51 microcontroller family. #### **DEVELOPMENT SYSTEM CONTACTS** | COMPANY | ADDRESS | TELEPHONE | | |-------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------|--| | Ashling Microsystems Limited | Plassey Technological Park<br>Limerick, Ireland | (353) 61 334 466 | | | | Eastern Systems Inc.<br>160 East Main Street<br>Westboro, MA 01581 | (508) 366-3220 | | | BSO Tasking | Norfolk Place<br>333 Elm Street<br>Dedham, MA 02026-4530 | (800) 458-8276 | | | Ceibo Ltd. | 105 Gleason Rd.<br>Lexington, MA 02173 | (617) 863-9927 | | | | Merkazim Building, Industrial Zone<br>P.O. Box 2106<br>Herzelia 46120, ISRAEL | 972-52-555387 | | | Lauterbach Datentechnik GmbH | Fichtenstrasse 27<br>85649 Hofolding<br>Germany | 49 8104 894 328 | | | | 945 Concord Street<br>Framingham, MA 01701 | (508) 620-4521 | | | MetaLink Corp. | 325 E. Elliot Road, Suite 23<br>Chandler, AZ 85225 | (602) 926–0797 | | | Nohau Corp. | 51 E. Campbell Ave.<br>Campbell, CA 95008-2053 | (408) 866–1820 | | | Philips Semiconductors | Corporate Centre Building BAE-2 P.O. Box 218 5600 MD Eindhoven The Netherlands | 31-40-724223 | | | SIGNUM Systems 171 E. Thousand Oaks Blvd.,<br>#202<br>Thousand Oaks, CA 91360 | | (805) 371-4608 | | #### **EPROM PROGRAMMING SUPPORT CONTACTS** | Advin Systems | Logical Devices, Inc. | North Valley Products | |---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------| | 1050-L East Duane Ave. | 1201 Northwest 65th Place | P.O. Box 32899 | | Sunnyvale, CA 94086 | Ft. Lauderdale, FL 33309 | San Jose, CA 95152 | | (408) 736-2503 | (305) 974-0967 | (408) 929-5345 | | BP Microsystems | Logical Systems | Strebor Data Communications | | 10681 Haddington #190 | P. O. Box 6184 | 1008 N. Nob Hill | | Houston, TX 77043 | Syracuse, NY 13217-6184 | American Fork, UT 84003 | | (800) 225-2102, (713) 461-9430 | (315) 478-0722 | (801) 756-3605 | | Data I/O Corp.<br>10525 Willows Road N.E.<br>P.O. Box 97046<br>Redmond, WA 98073-9746<br>(206) 881-6444 | Needham's Electronics<br>4535 Orange Grove Ave.<br>Sacramento, CA 95841<br>(916) 924-8037 | | # **SOFTWARE SUPPORT CONTACTS** | COMPANY | ADDRESS | TELEPHONE | | |---------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--| | Archimedes Software, Inc. | 2159 Union St.<br>San Francisco, CA 94123 | (415) 567–4010 | | | BSO/Tasking | Tasking Software BV P.O. Box 899 3800 AW Amersfoort The Netherlands Norfolk Place | 31-33-55-85-84 (Telephone)<br>31-33-55-00-33 (Fax)<br>(617) 320-9400 (Telephone) | | | | 333 Elm Street<br>Dedham, MA 02026-4530 | (617) 320-9212 (Fax)<br>(800) 458-8276 (Toll Free) | | | Franklin Software, Inc. | 888 Saratoga Ave. #2<br>San Jose, CA 95129 | (408) 296–8051 | | | Keil Software | Bretonischer Ring 15<br>85630 Grasbrunn<br>Germany | 49-89-46-50-57 (Telephone)<br>49-89-46-81-62 (Fax) | | # MICROCONTROLLER DEVELOPMENT SYSTEMS | PRODUCT | DEVICES SUPPORTED | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | NOHAU CORPORATION | | | | | EMUL51-PC/E32<br>EMUL51-PC/E32-16<br>EMUL51-PC/E32-16<br>EMUL51-PC/E128-16<br>EMUL51-PC/E128-20<br>EMUL51-PC/E128-30<br>EMUL51-PC/E128-30<br>EMUL51-PC/E128-33<br>EMUL51-PC/E128-BSW-16<br>EMUL51-PC/E128-BSW-24<br>EMUL51-PC/E256-BSW-24<br>EMUL51-PC/E256-BSW-16<br>EMUL51-PC/E256-BSW-16<br>EMUL51-PC/E256-BSW-16<br>EMUL51-PC/E256-BSW-16 | 12MHz Emulator, 32k emulation memory 12MHz Emulator, 128k emulation memory 16MHz Emulator, 32k emulation memory 16MHz Emulator, 128k emulation memory 20MHz Emulator, 128k emulation memory 24MHz Emulator, 128k emulation memory 30MHz Emulator, 128k emulation memory 33MHz Emulator, 128k emulation memory 12MHz Emulator, 128k emulation memory 12MHz Emulator, 128k bankswitched CODE memory 16MHz Emulator, 128k bankswitched CODE memory 12MHz Emulator, 256k bankswitched CODE memory 12MHz Emulator, 256k bankswitched CODE memory 24MHz Emulator, 256k bankswitched CODE memory 24MHz Emulator, 256k bankswitched CODE memory 24MHz Emulator, 256k bankswitched CODE memory | | | | LINIOLS 1-1 O/L230-DOVV-24 | 24WH2 Emiliator, 250k bankswitched CODE Memory | | | | POD-C054<br>POD-31<br>POD-C31<br>POD-C31-1<br>POD-C31-20<br>POD-C31-24<br>POD-C31-30<br>POD-C31-33<br>POD-32<br>POD-C32<br>POD-C32<br>POD-C32<br>POD-C652<br>POD-C652<br>POD-C652-16<br>POD-C51B | 12MHz 83C053, 83C054, 87C054, 87C055 pod 12MHz 80C31 pod 12MHz 80C31 pod 16MHz 80C31 pod 20MHz 80C31 pod 24MHz 80C31 pod 24MHz 80C31 pod 30MHz 80C31 pod 30MHz 80C31 pod 12MHz 80C32 pod 12MHz 80C32 pod 12MHz 80C32 pod 12MHz 80C32 pod 16MHz 80C32 pod 12MHz 80C652 pod 16MHz 80C652 pod 16MHz 80C652 pod 16MHz 80C652 pod 12MHz bondout pod for 8051, 80C51, 83C552, 83C654, 83C654, 83C851, and EPROM or ROMless versions of the above | | | | POD-C51B-16 | 16MHz bondout pod for 8051, 80C51, 83C552, 83C652, 83C654, 83C851, and EPROM or ROMiess versions of the above | | | | POD-C51B-24 | 24MHz version of the above | | | | POD-C52<br>POD-C52-16<br>POD-CL410 | 12MHz 80C32, 80C52, 87C52<br>16MHz 80C32, 80C52, 87C52<br>12MHz 80CL31, 80CL51, 83CL410, 83CL610 | | | | POD-C451-DIP<br>POD-C451-DIP-16<br>POD-C451-PGA<br>POD-C451-PGA-16<br>POD-C451B-PGA<br>POD-C451B-PGA-16 | 12MHz 80C451 DIP pod<br>16MHz 80C451 DIP pod<br>12MHz 80C451 PLCC pod (PGA from pod)<br>16MHz 80C451 PLCC pod (PGA from pod)<br>16MHz 80C451 PLCC pod (PGA from pod)<br>12MHz bondout pod for 83C451, 87C451, 80C451 PLCC (PGA from pod)<br>16MHz bondout pod for 83C451, 87C451, 80C451 PLCC (PGA from pod) | | | # MICROCONTROLLER DEVELOPMENT SYSTEMS (Continued) | PRODUCT | DEVICES SUPPORTED | | |-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| | NOHAU CORPORATION (Cont | inued) | N. 1995 | | POD-C528<br>POD-C528-16 | 12MHz 83C524, 87C524, 83C528, 87C528<br>16MHz 83C524, 87C524, 83C528, 87C528 | | | POD-C550-PGA<br>POD-C550-PGA-16 | 12MHz 80C550, 83C550, 87C550<br>16MHz 80C550, 83C550,87C550 | | | POD-C552-PGA<br>POD-C552B-PGA | 12MHz 80C552 PLCC (PGA from pod)<br>12MHz bondout pod for 83C552, 87C552, 80C552 PLCC (PGA from pod), 80C562, 83C562 | | | POD-C552B-PGA-16<br>POD-C552B-PGA-24<br>POD-C575<br>POD-C558-16<br>POD-CL580 | 16MHz bondout pod for 83C552, 87C552, 80C552 PLCC (PGA from pod), 80C562, 83C562 24MHz pod for 83552, 87C552, 80C552 12MHz 87C575 16MHz 83CE558, 89CE558 pod 12MHz bondout POD for 83CL580 | | | POD-C592-PGA<br>POD-C592-PGA-16 | 12MHz 80C592, 83C592, 87C592 pod<br>16MHz 80C592, 83C592, 87C592 pod | | | POD-C652B<br>POD-C851B | Order as POD-C51B<br>Order as POD-C51B | | | POD-C751<br>POD-C751-16<br>POD-C752<br>POD-C752-16<br>POD-CL782 | 12MHz 83C750, 87C750, 83C751, 87C751 pod<br>16MHz 83C750, 87C750, 83C751, 87C751 pod<br>12MHz 83C752, 87C752 pod<br>16MHz 83C752, 87C752 pod<br>12MHz 83CL781, 83CL782, 83CL52 pod | | | EMUL51-PC/TR4<br>EMUL51-PC/TR16<br>EMUL51-PC/TR4-16<br>EMUL51-PC/TR16-16 | 12MHz 4k trace buffer option 12MHz 16k trace buffer option 16MHz 4k trace buffer option 16MHz 16k trace buffer option | | | EMUL51-PC/TR16-20<br>EMUL51-PC/TR16-24<br>EMUL51-PC/TR16-30<br>EMUL51-PC/TR16-33 | 20MHz 16k trace buffer option 24MHz 16k trace buffer option 30MHz 16k trace buffer option 33MHz 16k trace buffer option | | | EMUL51-PC/ATR64-16<br>EMUL51-PC/ATR256-16<br>EMUL51-PC/ATR64-24<br>EMUL51-PC/ATR256-24<br>EMUL51-PC/ATR64-33<br>EMUL51-PC/ATR256-30 | 16MHz 64k Advanced Trace Option<br>16MHz 256k Advanced Trace Option<br>24MHz 64k Advanced Trace Option<br>24MHz 256k Advanced Trace Option<br>33MHz 64k Advanced Trace Option<br>30MHz 256k Advanced Trace Option | | | EMUL51-PC/BOX-CS<br>EMUL51-PC/BOX-CS-20<br>EMUL51-PC/BOX-CS-24<br>EMUL51-PC/BOX-CS-30 | Serial box with emulator (E128–16) and trace (TR16–16) Serial box with emulator (E128–20) and trace (TR16–20) Serial box with emulator (E128–24) and trace (TR16–24) Serial box with emulator (E128–30) and trace (TR16–30) | | | EMUL51-PC/BOX-S | Box with serial port and cable. Box allows operation of emulator external to PC. | | | METALINK CORPORATION | | | | IM-8051/200-20 | iceMASTER-8051 emulator Model 200, 32K emulation memory, 20MHz | | | IM-8051/400-20 | iceMASTER-8051 emulator Model 400, 32K emulation memory, 4K trace buffer, 2 performance analyzers, 20MHz | | | IM-8051/400-24 | iceMASTER-8051 emulator Model 400, 128K emulation memory, 4K trace buffer, 2 performance analyzers, 24MHz | | | 128KUP | 128K memory expansion option for iceMASTER-8051 | | | 752/1 PGMPC | Programmer accessory for iceMASTER to program 87C751, 87C752 | | | 8031–12PC | 0.5 to 12MHz 8031, 80C31<br>0.5 to 16MHz 8031, 80C31 | | | 8031–16PC<br>8031–20PC | 0.5 to 20MHz 8031, 80C31 | | | 8031-24PC | 0.5 to 24MHz 8031, 80C31 | | | 8032–12PC | 0.5 to 12MHz 8031, 80C31, 8032, 80C32 | | | 8032-16PC | 0.5 to 16MHz 8031, 80C31, 8032, 80C32 | | | 8032-20PC | 0.5 to 20MHz 8031, 80C31, 8032, 80C32 | | # MICROCONTROLLER DEVELOPMENT SYSTEMS (Continued) | PRODUCT | DEVICES SUPPORTED | | | |----------------------|---------------------------------------------------------------------------------------------|--|--| | METALINK CORPORATION | N (Continued) | | | | 8032-24PC | 0.5 to 24MHz 8032, 80C32, 8031, 80C31 | | | | 8052-12PC | 0.5 to 12MHz 8031, 80C31, 8032, 80C32, 8051, 8751, 80C51, 87C51, 8052, 8752, 80C52, 87C52 | | | | 8052-16PC | 0.5 to 16MHz 8031, 80C31, 8032, 80C32, 8051, 8751, 80C51, 87C51, 8052, 8752, 80C52, 87C52 | | | | 30410-12PC | 0.5 to 12MHz 80CL410 | | | | 80451-12PC | 1.2 to 12MHz 80C451 | | | | 80451-16PC | 1.2 to 16MHz 80C451 | | | | 80528-12PC | 1.2 to 12MHz 80C528 | | | | 80528-16PC | 1.2 to 16MHz 80C528 | | | | 80552-12PC | 1.2 to 12MHz 80C552, 80C562 | | | | 80552-16PC | 1.2 to 16MHz 80C552, 80C562 | | | | 80652-12PC | 1.2 to 12MHz 8031, 80C31, 80C652 | | | | 30652-16PC | 1.2 to 16MHz 8031, 80C31, 80C652 | | | | 30851-12PC | 1.2 to 12MHz 8031, 80C31, 80C851 | | | | 33053-12PC | 6 to 12MHz 83C053, 83C054, 87C054 | | | | 83451-12PC | 1.2 to 12MHz 80C451, 83C451, 87C451 | | | | 83528-12PC | 1.2 to 12MHz 80C528, 83C528, 87C528, 83C524, 87C524 | | | | 83528-16PC | 1.2 to 16MHz 80C528, 83C528, 87C528, 83C524, 87C524 | | | | 83550-10PC | 1.2 to 10MHz 80C550, 83C550, 87C550 | | | | 33552-12PC | 1.2 to 12MHz 80C552, 83C552, 87C552, 80C562, 83C562 | | | | 33552-16PC | 1.2 to 16MHz 80C552, 83C552, 87C552, 80C562, 83C562 | | | | 33652-12PC | 1.2 to 12MHz 80C652, 83C652, 87C652, 80C552, 83C552, 87C552, 80C562, 83C562 | | | | 33652-16PC | 1.2 to 16MHz 80C652, 83C652, 87C652, 80C552, 83C552, 87C552, 80C562, 83C562 | | | | 33654-12PC | 1.2 to 12MHz 80C652, 83C652, 87C652, 83C654, 87C654, 80C552, 83C552, 87C552, 80C562, 83C562 | | | | 33654-16PC | 1.2 to 16MHz 80C652, 83C652, 87C652, 83654, 87C654, 80C552, 83C552, 87C552, 80C562, 83C562 | | | | 33751-12PC | 0.5 to 12MHz 83C751, 87C751 | | | | 33751-16PC | 0.5 to 16MHz 83C751, 87C751 | | | | 33752-12PC | 0.5 to 12MHz 83C752, 87C752 | | | # **EPROM MICROCOMPUTER PROGRAMMING SUPPORT** | DEVICE | MANUFACTURER/MODEL | MODULE/ADAPTOR | SOFTWARE VERSION | | |---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------|--| | 37C054 SDIP | N. Valley Products<br>Philips, Ceibo MP-51 | SAM-054SD<br>PPA-054SD | | | | 37C51 DIP | Advin Sailor-PAL/SA, /SB BP Microsystems EP-1140 Ceibo MP-51 (PMP51SD) Data I/O Unisite 40 Data I/O Unisite 40 Data I/O Series 1000 Logical Devices ALLPRO N. Valley Products SPGM-100 Philips LCPX5X40 (P8051LCP40) Strebor PLP-S1A | Adaptor-8751 PPA-51XSD 351B103 SR40 SAM-51SD MC4851DIP | V2.2<br>V16<br>V05 (Use Intel 87C51 menu)<br>V1.47<br>V1.0 | | | 87C51 PLCC | Ceibo MP-51 (PMP51SD) Data I/O Unisite 40 Data I/O Unipak 2b Logical Devices ALLPRO N. Valley Products SPGM-100 Philips LCPX5X40 (P8051LCP40) | PPA-51XSD<br>Chipsite<br>351B103P<br>Required<br>SAM-51ASD | V2.3<br>V16<br>V1.47<br>V1.0 | | | 87C52 DIP | | | V23<br>V3.1 | | | 87C451 DIP | Ceibo MP-51 (PMP51SD)<br>Logical Devices ALLPRO<br>N. Valley Products SPGM-100 | PPA-451SD<br>PPRequired<br>SAM-451SD | V1.47<br>V1.0 | | | 87C451 PLCC | Advin Sailor-PAL/SA, /SB<br>Ceibo MP-51 (PMP51SD)<br>N. Valley Products SPGM-100<br>Data I/O Unisite<br>Philips LCPX5X (P8051LCPX) | Adaptor-87451<br>PPA-451ASD<br>SAM-451ASD<br>Chipsite | V1.0<br>V2.8 | | | 87C528 DIP | BP Microsystems EP-1140<br>Ceibo MP-51<br>N. Valley Products SPGM-100<br>Philips LCPX5X40 (P8051LCP40) | PPA-XSD<br>SAM-528 | | | | 87C528 PLCC Ceibo MP-51 (PMP51SD)<br>N. Valley Products SPGM-100<br>Philips LCPX5X40 (P8051LCP40) | | PPA-51XSD<br>SAM-528A | | | | 87C552 | | | V2.2<br>V3.1 | | | 7C652 DIP BP Microsystems EP-1140 Ceibo MP-51 N. Valley Products Philips LCPX5X40 (P8051LCP40) | | PPA-51XSD<br>SAM-52SD | | | | 87C652 PLCC | Ceibo MP-51 (PMP51SD)<br>Philips LCPX5X40 (P8051LCP40) | PPA-51XSD | | | | 87C654 DIP BP Microsystems EP-1140 Ceibo MP-51 (PMP51SD) N. Valley Products SPGM-100 Philips LCPX5X40 (P8051LCP40) | | PPA-51XSD<br>SAM-654SD | | | | 87C654 PLCC | 7C654 PLCC Ceibo MP-51 (PMP51SD)<br>Philips LCPX5X40 (P8051LCP40) | | | | # **EPROM MICROCOMPUTER PROGRAMMING SUPPORT (Continued)** | DEVICE | MANUFACTURER/MODEL | MODULE/ADAPTOR | V2.3 29B V6, Unipak 2B V20 V1.47 V1.0 V2.6a (use with MicrolCE+) | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--| | 87C751 DIP | Advin Sailor-PAL/SA, /SB BP Microsystems EP-1140 Ceibo MP-51 (PMP51SD) Data I/O Unisite 40 Data I/O 29B, Unipak 2b Logical Devices ALLPRO N. Valley Products SPGM-100 Needham's Electronics MetaLink Logical Systems (Sunshine EW-901) Philips LCPX5X (P8051LCPX) Strebor PLP-S1A | EM-751<br>HEAD-40A<br>PPA-751SD<br>351B113D<br>OPTAPC-751<br>SAM-751SD<br>752/1 PGMPC<br>PA751<br>MC7512DIP | | | | 87C751 PLCC Ceibo MP-51 (PMP51SD) Data I/O Unisite 40 Logical Devices ALLPRO N. Valley Products SPGM-100 | | PPA-51XSD<br>Chipsite<br>Required<br>SAM-751ASD | V2.6<br>V1.47<br>V1.0 | | | 87C752 DIP Advin Sailor-PAL/SA, /SB BP Microsystems EP-1140 Ceibo MP-51 (PMP51SD) Data I/O Unisite 40 N. Valley Products SPGM-100 Needham's Electronics MetaLink Logical Systems (Sunshine EW-901) Logical Devices ALLPRO Philips LCPXSX (P8051LCPX) Strebor PLP-S1A | | EM-751<br>HEAD-40A<br>PPA-752SD<br>SAM-752SD<br>752/1 PGMPC<br>PA751<br>OPTAPC-752<br>MC7512DIP | V2.6<br>V1.0 (Use Type 751)<br>V2.6a (use with MicroICE+) | | | 87C752 PLCC Ceibo MP-51 (PMP51SD) Data I/O Unisite 40 N. Valley Products SPGM-100 | | PPA-752ASD<br>Chipsite<br>SAM-752ASD | V2.8<br>V1.0 (Use Type 751) | | #### NOTE: Philips programmers are available in the U.S.A. through Philips Semiconductors distributors. # **ADDITIONAL PROGRAMMING SUPPORT** | DEVICE | MANUFACTURER | MODULE/ADAPTOR | COMMENTS | |-------------------------------|-----------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 87C51/52/652/<br>654/528 PLCC | Logical Systems | PA51-44 | Use with any 40-pin microcontroller programming site that supports the appropriate EPROM size. | | 87C51/52/652/<br>654/528 QFP | | PA52-QFP | Use with any 40-pin microcontroller programming site that supports the appropriate EPROM size. | | 87C451 DIP | | PA451-64 | Use with any 87C51 40-pin programming site. | | 87C451 PLCC | | PA451-68 | Use with any 87C51 40-pin programming site. | | 87C550 DIP | | 550BASE | Use with any 87C51 40-pin programming site. | | 87C550 PLCC | | PA550-44 | Use with any 87C51 40-pin programming site. | | 87C552 PLCC | | PA552-68 | Use with any 8752/C52/C252/C51FA 40-pin programming site. | | 87C752 PLCC | | PA28-28 | Use with any 87C752 28-pin DIP programmer. | | 87C751 PLCC | Philips | No part number assigned | This adapter allows programming the 87C751 PLCC part in conjunction with any programmer that can already program the DIP version of the part. | #### MICROCONTROLLER SUPPORT | PRODUCT | DEVICES SUPPORTED | MANUFACTURER | DESCRIPTION | | |--------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 8051 C Compiler<br>8051 C Compiler<br>80C51 C Compiler | 8051 and derivatives<br>8051 and derivatives<br>8051 and derivatives | Franklin Software<br>Archimedes Software<br>BSO/Tasking | C Compiler for 8051 family<br>C Compiler for 8051 family<br>C Compiler for 8051 family | | | P8051DB | 8051 and derivatives | Ceibo | 80C51 Family Development Board | | | S87C00KSD | | Philips | I <sup>2</sup> C Demonstration Board. 87C751 controls various I <sup>2</sup> C peripherals. Board has sockets for 87C752, 87C652, and 87C552 also. | | | / | | Philips | The Philips computer Bulletin Board system has available a microcontroller newsletter, application and demonstration programs for download, and the ability to send messages t microcontroler applications engineers. Access by modem a 2400, 1200, or 300 baud. The telephone numbers are: (800) 451–6644 (in the U.S.) or (408) 991–2406. | | | SMI-CNV451SD | 80/83/87C451 | Philips | Philips product adapts a PLCC emulator plug for the 80C451 to the DIP pinout. | | Ashling's CTS51 Universal Microprocessor Development System for Philips Microcontrollers #### Features of Ashling's Microprocessor Development systems: - ♦ Integrated Development Environment for Philips 8051 under Windows - Real-time in-circuit emulator for all Philips 8051 derivatives; full-speed, non-intrusive emulation - ♦ Real-time, DSP-based Performance Analysis and Code Coverage systems for Software Quality Assurance - ♦ Source-Level Debugging for 8051 programs, under Windows and DOS hosts - Emulation and probe support for Philips low-voltage microcontrollers and Smart-Card microcontrollers - Hardware break-before-execute breakpoints at every code and data address - ♦ Stand-alone system, with built-in power supply; interchangeable probe cards for all derivatives and packages - ♦ Programmer for all Philips 8051-family EPROM and EEPROM microcontrollers - ♦ ISO9001-Certified Supplier; Ashling Microsystems Ltd. is certified to EN ISO9001/ASQC Q91 766 The Development Systems Company October 1994 #### **Product Information** Ashling's CTS51 Universal Microprocessor Development System provides a complete hardware and software development environment for the Philips 8051 microcontroller family and all of its derivatives. #### In-Circuit Emulator The CTS51 In-Circuit Emulator provides real-time emulation in both Single-Chip and Expanded modes. Target voltages in the range 2.7 - 5 Volts are supported; the emulation voltage can be set at 3.0, 3.3V or 5.0V, or can track the target system voltage throughout the range. #### **ICE Probes** In-Circuit emulation probes are available for all device-packages, including DIP-24, DIP-28, DIP-40, PLCC-44, QFP-44, SDIP-42, SDIP-52, PLCC68, QFP-80, QFP-100, and Philips Smart-Card Microcontrollers in ISO7816 or SIM (GSM) card-format. #### **Devices Supported** Using field-upgradeable personality probes, the CTS51 Universal Development System supports all Philips 8051 derivatives, including: | 80C51B/80C31B | 80C31/80C52 80CL51 | 83C550/83C550 | 80C51FA/FB/FC | |----------------------|----------------------|------------------|---------------| | 83C552/80C552 | 83C562/80C562 | 83C053/54 83C654 | PCD509x | | 83C750 83C751 83C752 | 83C851 | 83CE598/80CE598 | SAA5290 | | 83C592/80C592 | 83C528/80C528 83C575 | 83CE558/80CE558 | 83CL434 | | 83CL410 83CL580 | 83CL782 | 83C852/855 | 83CL168 | #### Support for new Philips microcontrollers Ashling's close technical collaboration with Philips Semiconductors ensures that new Philips microcontroller devices and device-architectures are supported at, or soon after, their introduction by Philips. New Ashling personality probes are regularly introduced for new standard microcontrollers, and microcontroller-based ASICs from Philips. #### Philips Smart Card development support Developed in co-operation with Philips, Ashling's CTS51 Microprocessor Development System provides a complete development-environment for Philips' 8CC852, 83C852 family of Smart Card Microcontrollers. Probes are available for ISO7816 and GSM (SIM) card formats. Ashling also supplies the SCPC4281 Smart Card Verification kit for stand-alone smart-card program emulation. #### ISO9001 Certification; Quality Management System Ashling Microsystems Ltd. operates a company-wide Quality Management System, formally certified to the ISO9001 international standard (NSAI Registration No. M619). This certification applies to all of Ashling's product development, manufacturing and customer-support activities. The Development Systems Company October 1994 767 Ashling WinIDEAS: With the Windows Integrated Development Environment for Ashling Systems supports the full Philips Microcontroller family. A single keystroke moves you between the edit, help-lookup, compile, debug and emulate stages. # **Integrated Development Environment** WinIDEAS, the Windows Integrated Development Environment for Ashling Systems, allows you to edit, compile, assemble, simulate, debug, download and execute code on your Philips microcontroller target system in the Windows environment throughout. WinIDEAS provides a uniform, flexible and extensible windows interface for Editing, C Compiling, Assembling, Fuzzy-logic design and compilation, Linking, Incircuit emulation, Performance Analysis, Code Coverage Measurement, Software Validation reporting, and EPROM/EEPROM programming on Philips Microcontroller projects. #### System Execution Analyser The System Execution Analyser (SEA) is a built-in, DSP-based option for Ashling's Universal Microprocessor Development System. It provides real-time, non-intrusive, non-statistical Performance Analysis, Code Coverage and Report Generation. The SEA also provides symbolic function-trace, time-stamping, timing analysis and software verification. You can measure maximum, minimum and average execution times, execution counts and percentage code execution at Source or Assembly level. The Development Systems Company October 1994 768 #### **Code Coverage System** The Code Test Management (CTMS) option for the Ashling's Universal Microcontroller Development System measures 8051 code execution in real-time throughout a test session. It maps tested and untested code; identifies all tested, partially-tested or untested C source statements and assembler instructions; generates formal, annotated, test reports; identifies redundant code; and provides a formal measurement of test completeness. This PathFinder for Windows screen shows the Source program, Disassembly, Real-Time Trace (source-level, disassembly and opcodes), Variables-watch, On-chip Registers and Stack contents for an 8051 program. #### Windows Source-Level Debugger Ashling's "PathFinder for Windows" Source-Level debugger supports all popular microcontroller C and PL/M Compilers and Assemblers for the Philips microcontroller device family. PathFinder provides up to 20 display-windows, controlled by mouse, menu-bar, command-line, accelerator keys or button-bar. Assembly-language source level debugging is a unique feature of PathFinder for Windows. The Development Systems Company October 1994 769 #### Microcontroller EPROM/EEPROM Programming Ashling's CTP51 Prom Programming System is used with the Universal Microprocessor Development System, to program the entire Philips 8751 EPROM/EEPROM microcontroller family. Features include: - Programming support for all Philips 8751-family EPROM microcontrollers, including 87C51, 87C51FC, 87C52, 87C528, 87C550, 87C552, 87C592, 87C751 and 87C752; plus all Philips 89C51-family EEPROM microcontrollers, including 89CE528, 89CE558, 89CE598 and SAA5290NV. - Software-driven programming data files allow easy upgrade for new Philips devices. - Programming Adapters are available for all Philips EPROM/EEPROM microcontroller packages. # Ashling Microsystems' Distributors: | AUSTRALIA: | Metromatics Pty. Ltd. | Tel: 07-3585155 | Fax: 07-2541440 | |--------------|----------------------------|----------------------|----------------------| | AUSTRIA: | Ashling Mikrosysteme | Tel: 08202 1276 | Fax: 08202 8745 | | BELGIUM: | Air Parts Electronics | Tel: 02 241 64 60 | Fax: 02 241 81 30 | | FRANCE: | Ashling Microsystèmes sarl | Tél: (1) 46.66.27.50 | Fax: (1) 46.74.99.88 | | GERMANY: | Ashling Mikrosysteme | Tel: 08202 1276 | Fax: 08202 8745 | | HUNGARY: | Vanguard Kft. | Tel: (1) 156-9000 | Fax: (1) 156-8982 | | IRELAND: | Ashling Microsystems Ltd | Tel: 061-334466 | Fax: 061-334477 | | ISRAEL: | RDT Ltd. | Tel: 03-6450745 | Fax: 03-6478908 | | ITALY: | All-Data s.r.l. | Tel: 02-66015566 | Fax: 02-66015577 | | KOREA: | DaSan Technology | Tel: (02) 501 8277 | Fax: (02) 501 8276 | | NETHERLANDS: | Air Parts b.v. | Tel: 01720-43221 | Fax: 01720-20651 | | SPAIN: | Sistemas Jasper s.l. | Tel: (1) 803 8526 | Fax: (1) 803 8526 | | SWEDEN: | Ferner Elektronik AB | Tel: 08-760 8360 | Fax: 08-760 8341 | | SWITZERLAND: | Litronic AG | Tel: 061 421 3201 | Fax: 061 421 1802 | | U.K.: | Ashling Microsystems Ltd. | Tel: (01628) 773070 | Fax: (01628) 773009 | | U.S.A: | Eastern Systems Inc | Tel: (508) 366 3220 | Fax: (508) 366 1520 | Ashling Microsystèmes sarl 2, rue Alexis de Tocqueville Parc d'Activités Antony 2 92183 ANTONY - France. (1) 46.66.27.50 Télécopieur: (1) 46.74.99.88 Ashling Microsystems Ltd Plassey Technological Park Limerick Ireland Tel: +353-61-334466 Fax: +353-61-334477 Ashling Mikrosysteme Waldstraße 18 86510 Ried-Baindlkirch Germany. Tel: 08202-1276 Fax: 08202-8745 Eastern Systems Inc. 160 East Main Street Westboro MA 01581, USA Tel: (508) 366 3220 Fax: (508) 366 1520 770 Ashling Microsystems Ltd. Butler House, Market St. Maidenhead Berks. SL6 8AA, U.K. Tel: (01628) 773070 Fax: (01628) 773009 The Development Systems Company doc:philipdb.doc/cb Oct 94 ver. 1.0 # BSO/TASKING # The Total Development Solution for the 8051 Family The BSO/TASKING C-51 cross-compiler offers a new approach to high-level language programming for the 8051 family. It combines our 15+ years of experience in producing software tools for the embedded marketplace and our considerable expertise with the 8051 microcontroller. Although intended as a general purpose programming language, C is perhaps most powerful in the area of real-time programming for embedded microcontrollers. Since the operators and type definitions match so well with the instruction sets and word lengths of microcontrollers, C is very efficient in terms of code size and execution speed for these devices. # C Compiler Efficient ANSI C compiler with powerful 8051 extensions for all derivatives #### Assembler Intel compatible macro assembler and linker/locator with libraries supplied in source # CrossView Debugger C and assembly level debugging with a full Windows interface # the C Compiler The BSO/TASKING 8051 C compiler is built using the latest compiler technology, including optimization and multi-layering. It is essentially a one pass compiler, translating on a function by function basis, achieving very fast compilation and a large span for the optimization process. Significant effort was made to obtain a well-defined, layered product. The top layer basically consists of a lexical and grammar analyzer with co-routine structures to serve both the preprocessing and compilation needs. The grammar analyzer is produced by an LALR(1) parser generator, eliminating a potential source of error. A second layer separates the actual code-generation layer from the top layer and simplifies retargeting of the compiler to other target processors. This is where most of the optimizations are done and it is designed to represent the translated program independent of the language and the target. The code-generation layer is driven both by the second layer and by a set of tables and rules reflecting the target assembly language and the behavior of individual instructions. The 8051 family ANSI C compiler uses a number of sophisticated techniques to produce highly efficient code. The features that ANSI has brought to C compilers, together with the BSO/TASKING 8051 specific features and extensions brings a new dimension to programming the 8051 microcontroller family: - Full ANSI C to ensure early error detection - •Complete 8051 family support - In-line assembly - •Single precision floating point - •Memory keywords; data, idat, pdat, xdat and rom - •C level access to special function registers - •C level bit, interrupt and bit addressable 'chars' & 'ints' - · Automatic register bank switching - ·Data overlay mechanism - Powerful extensions including: - bit-type to use the on-chip bit addressable area - interrupt <number> and using <registerbank> for interrupt servicing at C-level - Generates Intel compatible assembly source - Outputs symbol information for source level debugging - 4 memory models to best meet application requirements - Complete C and run-time library support, - · Generates reentrant and relocatable code and data - •Full Intel OMF51 and IEEE695 v4.1 object formats - Full calling interface with parameter passing to our PL/M51 compiler - Intelligent configuration of startup code - Keyword \_at to connect a global or static variable to a logical address #### ▲ Efficiency The C compiler has a number of features which make code production very efficient. The compiler also makes use of 8051 memory very efficiently. - Function prototyping gives the user control over the size of parameters - Parameter passing between functions is done using static 'fast internal RAM' - ·Pointer sizes are automatically determined - The compiler recognizes automatic variables and register variables that are used repeatedly and stores them in internal RAM - In-line expansion of predefined functions such as 'rol', 'ror', 'da', 'testclear', 'setbit', 'putbit' - Character 'switch' statement produces fast inline code - Very efficient pointer arithmetic - Fast 8 bit char arithmetic - Fast parameter passing by avoiding the stack. ### ▲ The Target Environment There are specific features in the 8051 C compiler that let the user tailor the output to the specific target environment - •4 Different memory models see next page - Interrupt service routines can be written in C or assembly language - ROMable code - •8051 derivative is switch selectable - User controlled mapping of code and data # ▲ Memory Models The compiler supports 4 different memory models: small, auxpage, large and reentrant. This enables the compiler to generate the best possible code for the particular hardware implementation. See the Memory Model table. #### ▲ Data Types All ANSI types are supported. In addition to these types, bit, sfrbyte, sfrbit and bitbyte are added. The keywords sfrbyte and sfrbit are available to access special function registers which deal with I/O. Sfr's are treated like variables declared with the volatile type qualifier. #### ▲ Data Sizes | <u>type</u> | size (in bytes) | | |----------------------|-----------------|----------------| | bit | 1 bit | | | char | 1 | | | short int | 2 | | | int | 2 4 | | | long int | 4 | | | float, (long) double | 4 (IEEE sin | gle precision) | | pointer type | 1 or 2 | | Pointers to data, idata and pdat have a size of 1 byte, but pointers to rom, xdat and functions have a size of 2 bytes. #### ▲ Code Optimizations The compiler intermediate layer performs general code optimizations and the code generator does some final 8051 specific optimizations. General optimizations include: - Register allocation - Branch optimization - Dead code elimination - Constant folding - Arithmetic simplification - ·Strength reduction - Jump chaining - Common subexpression elimination - Loop rotation - Induction variable elimination - ·Sharing of string literals Code generator optimizations: - Store-copy optimization - Peephole optimization #### ▲ Pragmas The #pragma directive supplies target dependent data to the compiler without violating the ANSI C language, making the resultant program portable. In the BSO/ TASKING C 8051 compiler pragmas are used to merge C lines with generated assembly, to control code generation for interrupt service routines and to support inline assembly programming. #### ▲ Libraries The compiler is delivered with libraries for all combinations of the 8051 family. The libraries include ANSI C libraries, run time libraries including I/O calls (+ printf), memory management, arithmetic functions and floating point. Special libraries are included for floating point using internal RAM only. There is also a separate library to support the 80C751 derivative. Source code is provided for most of the library routines allowing the user to tailor the libraries to their specific application. #### ▲ Compiler Switches - -? Display invocation syntax - -Ccpu Use special function register definitions for cpu - -Dmc[=df] Define preprocessor macro # ▲ Memory Models model data allocation small static, in on-chip direct addressable RAM (data) auxpage static, in first page of external RAM (pdat) large static, in external RAM (xdat) reentrant dynamic + static, in external RAM (xdat) -Hfile Include file before starting compilation -Idirectory Look in directory for include files Compile using small memory model -Ms -Ma Compile using auxpage memory model -Ml Compile using large memory model Compile using reentrant memory model -Mr -N Check for use of new style prototyping Relax alias checking -Oa OA Strict alias checking -Oc Enable common subexpression elimination (CSE) -OC Disable CSE Enable constant and copy propagation -Od -OD Disable constant and copy propagation Produce fast code -Of -OF Produce small code -Og Enable global CSE Disable global CSE -OG Overlay data -Oo -00 Do not overlay data Enable loop variable detection -Ov -OV Disable variable detection -Rm[=nm] Change segment name --S Put strings in ROM only \_Umac Remove preprocessor macro Change allocated space for variable argument list -asize -bnumber Specify default register bank number Remove output file if compilation errors occur -e Send diagnostics to error list file -err -f file Read options from file Enable symbolic debug information -g Enable symbolic debug information with function -gt Enable symbolic debug information for older -go debugger versions Generate listfile -1 -li Generate listfile with expanded include files -mm=size Specify memory size Send output to standard output -n Specify output file name -o file Select small ROM model -rs Select medium ROM model -rm Select large ROM model -rl Merge C source code with assembly output -S -t Display module summary Treat 'char' variables as unsigned -11 Don't generate interrupt vectors Suppress warning messages, or just one indicated by -w[num] Preprocess only or emit dependencies -E[m] its number -xsize Extend amount of internal RAM for automatics application fast programs in small environments derivatives with 256 bytes on-chip "external" RAM fast, non reentrant with large external RAM large, reentrant programs in large environments # the Assembler The BSO/TASKING assembler is an integral part of the toolset and delivers features that enable it to be used on its own. It is supplied complete with linker/locator, librarian and object format utilities. The 8051 assembler translates 8051 assembly language into relocatable object code. The assembler accepts Intel compatible assembler source programs and produces relocatable (.obj) object files. An absolute or executable load image is then obtained by using the linker/locator. Features of the assembler include: - Produces relocatable object code and listing files - Accepts Intel compatible source programs - Supports all members of the 8051 family - Compatible with BSO/TASKING C and PL/M 8051 compilers - Compatible with high level and assembly level debuggers - Optimizes jmp/call instructions from the compiler - · Supports segment overlay at the assembly level - Intel compatible macro preprocessor - Number of symbols only limited by available host memory - Extensive section directives - Error file with textual error reporting #### the Linker/Locator The linker and locator is an essential part of the software building process that enables you to configure the code to match your target environment. The linker/locator brings together all the necessary relocatable objects, including library modules, resolves external references and then locates the modules in memory according to your specification. Features include: - Intel compatible linker controls - Accepts object files and object libraries in the Intel OMF-51 file format. - Supports absolute Intel OMF-51 and IEEE695 object formats - Automatic segment overlaying using information from the compiler and assembler - Absolute map files and diagnostic messages - •Incremental linking - · Automatic inclusion of library modules - •Map listing to help with debugging #### Utilities #### ▲ Librarian Listing utility with numerous options for showing: - section records - symbol table - code bytes and much more Format conversion utilities #### ▲ EDE BSO/TASKING's new embedded development environment for the PC which includes: - make utility - C interface generator - line searcher and sorter - interface to INTERSOLV PVCS #### Availability C compiler and Assembler are available now to run on: PC DOS SUN SPARC SUNOS HP9000 HPUX SUN SPARC Solaris VAX VMS IBM RS6000 AIX # Available from Philips as: OM4144 80C51 Cross-Assembler / PL/M-Compiler package for PC/DOS OM4285 80C51 Cross-Assembler / C-Compiler package for PC/DOS OM4286 Cross View PC/DOS – MS/Windows Debugger for SDS80C51 (OM4120S) 8051 Tool-chain overview # the Debugger CrossView Windows CrossView is our high level language debugger designed to deliver functionality that will reduce the time spent testing and debugging. It combines the flexibility of the C language with the control of code execution found in assembly language debugging. CrossView brings the full power of Microsoft and X Windows to the debugging environment by displaying and updating the most critical execution data in an organized way. #### **Productive Debugging** CrossView has a number of productive debugging features designed specially for the embedded systems programmer: ▲ Single Stepping allows you to watch a program execute line by line. You can step single lines of source or, step in or over procedure calls. - ▲ Code in C Debug in C. Automatic correlation of variables and line numbers - ▲ Stack Trace shows the program's function calling path. Function calling sequence and parameter values passed are displayed at each level. - ▲ Code breakpoints let you halt the program in critical places and observe values. Code breakpoints can be permanent, temporary or conditional by specifying standard C conditions - ▲ Assertions let you execute user specified command lists after running every line of source code. This is the software equivalent of data breakpoints, they can be used to set up sophisticated error checking mechanisms that uncover the most elusive bug. - ▲ Simulated I/O enables you to debug without input/ output devices being available. Screen, keyboard or files can be used as I/O devices and eight streams can be active at a time. - Data Monitoring is used to monitor any expression or variable continually. - ▲ C Expression Evaluation lets you enter C expressions or CrossView commands in any combination and have them evaluated. You can even evaluate expressions which call functions defined in the source code. - ▲ Command Line Function Calls used to pass sample parameter values and then checking the result is an ideal way to test subroutines. - Macros let you store and recall complex commands and expressions via buttons. - ▲ Context Sensitive Help provides complete command syntax and detailed description with hypertext links to the user manual. - ▲ On-Line Tutorial is included and demonstrates the use of common CrossView command and debugging techniques in a real on-line debugging session. # #### Multi-window Interface CrossView brings the full power of Microsoft and X Windows to organize and display every facet of the application as it is running in the target system. CrossView features multiple child windows, extensive menus and dialog boxes and user programmable buttons for macros. CrossView also has an accelerator bar which provides quick access to frequently used debugging commands. Windows available include: - Command Window - · Stack Window - Source Window - · Simulated I/O Window - Data Window - Breakpoint Window - Register Window - Help Window - · Macro Window - Trace window #### **ROM Monitor Environment** CrossView is supplied with a monitor for loading into RAM or ROM and can be configured for any 8051 family target board. All files required to build the monitor are shipped as source with CrossView, including a make file and documentation for retargeting the monitor. The monitor program is approximately 3Kb. The internal data requirements are kept to a minimum: it only uses register bank 3, 20 bytes of stack space and 12 bits in bit addressable memory. All other monitor data (74 bytes) is stored in external memory CrossView communicates with the monitor on the target board via an RS232 interface. It is possible to communicate directly with the ROM monitor with a terminal only, or from within CrossView via transparency mode. #### Transparency Mode CrossView enables direct communication with the target to give you access to the low level hardware features of the target system. There are 35 monitor commands which manipulate the registers, memory control execution. #### Availability CrossView Windows for 8051 will be available to run on: PC DOS SUN SPARC SUNOS HP9000 HPUX SUN SPARC Solaris VAX VMS IBM RS6000 AIX #### **Customer Support** Purchasing BSO/TASKING products marks the beginning of a long term relationship. BSO/TASKING is dedicated to providing quality products and support worldwide. This support includes program quality control, product update service and support personnel to answer questions by telephone or fax. BSO/TASKING product support begins before the purchase of any of our products with extensive testing in order to ensure our high standard of quality assurance. A 90 day maintenance plan is included with the purchase of BSO/TASKING products and entitles the customer to enhancements and improvements as well as individual response to problems. Annual maintenance contracts are available at the end of the 90 day maintenance plan. This extremely valuable service, in return for a small annual fee, provides the user with all program enhancements released during the period of the program maintenance agreement, and assures response to all problem reports submitted by the user. # **BSO/TASKING** BSO/TASKING is an international software manufacturing company with headquarters in Massachusetts. Founded in 1974, BSO/TASKING is privately held with 100+ employees and revenues of \$19M. BSO/TASKING has offices in the United States, the Netherlands, Italy, Japan, Germany and the United Kingdom. BSO/TASKING develops, manufactures, and supports software development tools for DOS, Unix and VMS programming environments. In 1974, the company pioneered the concept of 'cross development' on DEC platforms. Today, BSO/TASKING is the leading supplier of software development tools for embedded and system applications across industry standard computing platforms. Software Products from BSO/TASKING are developed with great care at our innovative "Software Factory". A fully integrated environment for software development, modeled after and compatible with the standards defined in the ESPRIT project PCTE (Portable Common Tool Environment). This paradigm facilitates the creation of tools that execute in multiple environments (DOS, Unix, VMS) from a single master source file that is then verified with the Plum Hall Test Suite. To complement the software development tools BSO/ TASKING delivers cost effective hardware systems - incircuit emulators and evaluation boards - integrated with our software to provide you with a Total Solution for all your embedded development needs. BSO/TASKING also provides consulting and training services to complement each product area. BSO/TASKING supports products on PC/DOS, Sun SPARC, DEC VMS, DECStation/Ultrix, IBM RS6000, HP9000/300,400,700. The company mission is to provide customers with highly integrated, leading-edge cross software development tools across industry standard computing platforms, coupled with the most comprehensive support and training services available. Boston Systems Office, BSO, Boston Systems Office/TASKING, BSO/TASKING and CrossView are registered trademarks of Boston Systems Office Inc and TASKING B.V. BSO/Tasking assumes no responsibility for any errors which may appear in this document. BSO/TASKING retains the right to make changes to the specification at any time, without notice. Contact your local sales office to obtain the latest information. # CEIBO DB-51 Development Board Development Board for Philips 80C51 Microcontrollers # **FEATURES** - Supports Most of the Philips 80C51 Microcontrollers - Serially linked to IBM PC or Compatible Hosts - 32K of User Code Memory - Software Breakpoints - Examine and Alter Chip Registers, RAM and Ports - Source Level Debugger - Upload and Download of Object and Hex Files - Special Wire-Wrap Area for Prototyping - User's Manual with Examples and Applications # CEIBO DB-51 Development Board DB-51 is a high-performance system design board dedicated to the Philips 80C51 family of microcontrollers. It provides an easy-to-use flexible instrument which enables the user to build a primary prototype, analyze and debug it, make changes and continue debugging. You can improve your design decisions by using the DB-51 to check and test the advantages of several different microcontrollers. The DB-51 is also a great training and tutorial aid for becoming familiar with designs using the 80C51 architecture. Note that the DB-51 is not intended to replace a full emulator system in complex microcontroller designs. # **SPECIFICATIONS** #### SYSTEM MEMORY DB-51 provides 32K of user code memory. This RAM memory permits downloading and modifying of user's programs. #### **BREAKPOINTS** Breakpoints allow real-time program execution until an opcode is executed at a specified address. #### **CONDITIONAL BREAKPOINTS** A complete set of conditional breakpoints permits halting program emulation on code addresses, source code lines, access to on-chip memory, ports and register contents. #### **USER SOFTWARE** The board is provided with a very easy-to-use menu-driven software program as well as command orientated user interface software. On-line Assembler and Disassembler are provided together with upload and download capabilities of hexadecimal and object files. Also, DB-51 includes the following functions: Source Level Debugger for PLM and C, Software Trace, Conditional Breakpoints, Performance Analyzer and a unique Assembler Debugger. #### SOURCE LEVEL DEBUGGER DB-51 gives full support for debugging directly in PLM and C source code. From your code source you can specify a breakpoint, execute a line step or an assembly instruction, open a flexible-in-size watch window to display any variable, use the function keys to display the trace memory, registers and data, redefine the Program Counter and reset the microcontroller. #### **SOFTWARE ANALYZER** A 64 KByte buffer is used to record any software and hardware events of your program, such as executed code, memory accesses, port and internal register states, on-chip data memory and others. The trace buffer can be viewed in disassembled symbolics or high-level language source code. #### LANGUAGES AND FILE FORMATS DB-51 accepts files generated by Intel software (Assembler, PLM) or compatibles in hex or object formats. Other assemblers and high-level languages such as C with Intel OMF51 compatible format (Franklin, Archimedes, IAR, etc.) are also supported. #### SUPPORTED MICROCONTROLLERS 8x31/51, 8x32/52, 8xC31/51, 8xC32/52, 8xC652, 8xC654, 8xC851, 8xC550, 8xC552, 8xC562, 8xC451, 8xC528 and others with external memory addressing and a UART are fully supported. 8xCL410, 8xC751 and 8xC752 have very limited support. #### LIMITATIONS "Fully supported" microcontrollers are self-debugging on the DB-51. Thus, some of the chip resources are used by the board: the monitor program uses the bottom 32K of program memory; chips are always operated in the external memory mode; the UART is used to communicate with the PC and is not normally available to the user program; interrupt response is slowed slightly by re-vectoring from the monitor program to the user program; use of watchdog timers and power-down and idle modes of operation are limited due to interaction with the monitor program. "Limited support" microcontrollers do not have onchip UARTs and most do not support external program memory. Thus, download of programs to these parts is not supported on the DB-51. The 87C751 provided with the board is preprogrammed with a "micro" monitor program and some predefined experiments described in the user manual. Also, these parts use the I-C bus to communicate with the PC, limiting the use of I-C for other purposes. #### **INPUT POWER** 7.5 VDC to 12.0 VDC (9 VDC wall transformer supplied). #### MECHANICAL DIMENSIONS 20cm x 25cm. #### ITEMS SUPPLIED AS STANDARD DB-51 board, 80C552 and 87C751 microcontrollers, monitor EPROM, power supply, RS-232 cable. User software including Symbolic Debugger, On-line Assembler and Disassembler. User's Manual and Operating Instructions. # **Ordering Information** #### Part No. P8051DB SD/OM4238 Available through Philips distributors. 12NC:9350-360-40112 Product and Company names are trademarks of their respective organizations. # CEIBO DS-51 Microprocessor Development System In-Circuit Emulator for 8051 Family of Microcontrollers # **FEATURES** - Real-Time and Transparent In-Circuit Emulator - Supports Most of the 8051 Derivatives - Emulates 1.5V to 6V Microcontrollers - Maximum Frequency of 42MHz - 128K of Internal Memory - 32K Trace Memory and Logic Analyzer - 64K Hardware and Conditional Breakpoints - Source Level Debugger for Assembler, PLM and C - On-line Assembler and Disassembler - Performance Analyzer - Serially linked to IBM PC at 115 KBaud CEIBO TEL: 314-830-4084 FAX: 314-8304083 #### **EIBO DS-51 In-Circuit Emulator** #### **ESCRIPTION** 3-51 is a real-time in-circuit emulator dedicated to the 8051 family of microcontrollers. It is serially linked to a C/XT/AT or compatible systems and carries out a transparent emulation on the target microcontroller. ne system emulates almost every 8051 derivative in the complete voltage and frequency range specified by the icrocontroller manufacturer. S-51 also supports the new low-power and low-voltage 8051 microcontrollers and derivatives and can emulate e microcontrollers using either the built-in 5V power supply or any voltage applied to the target circuitry. The emitted voltage range is from 1.5V to 6V or higher. ne software includes Source Level Debugger for PLM and C, a unique Assembler Debugger, Performance nalyzer, On-line Assembler and Disassembler, Conditional Breakpoints and many other features. les generated by the most common 8051 Assemblers and High-Level Language Compilers are accepted by S-51. tandard systems are supplied with 128 KBytes of internal memory, 64K hardware breakpoints, 32K real-time ace memory and logic analyzer with external test points, and personality probe C51 supporting most of the 40-in DIP or 44-pin PLCC/QFP microcontrollers. #### **UPPORTED DEVICES** ROBE MICROCONTROLLER | 51 | 8051, 8751, 8031, 8052, 8752, 8032, 80C51, 87C51, 80C31, 80C52, 87C52, 80C32, 87C51FA, 87C51FB, 87C51FC, 87C54, 87C58, 83C504, 87C504, 83C524, 87C524, 80C528, 83C528, 87C528, 80C550, 83C550, 87C550, 80C652, 83C652, 87C652, 83C654, 87C654. | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | :168 | 83CL167, 83CL168, 83CL267, 83CL268. | | :410 | 80CL31, 80CL51, 80CL410, 83CL410, from 1.5V to 6V. | | ;434 | 83CL434, 83CL834, 87CL134. | | <b>;451</b> | 80C451, 83C451, 87C451, 87C453. | | 552 | 80C552, 83C552, 87C552, 80C562, 83C562. | | 2558 | 80C558, 83C558, 89C558, 83C559, 89C559. | | 3575 | 80C575, 83C575, 87C575, 83C576, 87C576. | | 2580 | 80CL580, 83CL580 from 1.5V to 6V. | | )592 | 80C592, 83C592, 87C592. | | 2598 | 80C598, 83C598, 87C598. | | 2752 | 83C748, 87C748, 83C749, 87C749, 83C750, 87C750, 83C751, 87C751, 83C752, 87C752. | | 2781 | 83CL781, 83CL782, 80CL32, 80CL52 from 1.5V to 6V. | | 2055 | 83C054, 87C054, 83C055, 87C055 | Consult Ceibo for other Supported microcontrollers. CEIBO TEL: 314-830-4084 FAX: 314-8304083 781 #### CEIBO DS-51 In-Circuit Fmulator #### **SPECIFICATIONS** # **EMULATOR MEMORY** DS-51 provides 128 KBytes of code memory with software mapping and banking capabilities #### HARDWARE BREAKPOINTS Breakpoints allow real-time program execution until an opcode is executed at a specified address. Breakpoints on data read or write and an AND/OR combination of two external signals are also implemented #### **CONDITIONAL BREAKPOINTS** A complete set of conditional breakpoints permit halting program emulation on code addresses, source code lines, access to external and on-chip memory, port and register contents. #### SOFTWARE ANALYZER A 64 KByte buffer is used to record any software and hardware events of your program, such as executed code memory accesses, port and internal register states, external or on-chip data memory contents and more #### LANGUAGES AND FILE FORMATS DS-51 accepts files with Intel OMF51 object or hex format. Assemblers and high-level languages such as C with OMF51 format (Intel, Franklin, Archimedes, IAR, MCC, BSO/Tasking, etc.) are also supported #### SOURCE LEVEL DEBUGGER The DS-51 Software includes a Source Level Debugger. This function may be used to debug code written ir Assembler, PLM and C. The Source Level Debugger includes commands which allow the user to get all the information necessary for testing the programs and hardware in real-time. The commands permit setting breakpoints on high-level language lines, adding a watch window with the symbols and variables of interest modifying variables, displaying floating point values, showing the trace buffer, executing assembly steps and many more useful functions. #### **PERSONALITY PROBES** DS-51 uses standard and bond-out microcontrollers for hardware and software emulation. The selection of a different microcontroller is made by replacing the microcontroller on the probe or changing the probe. The Personality Probes run at the frequency of the crystal on them or from the clock source supplied by the user hardware. Therefore, the same probe may be adapted to your frequency requirements. The minimum and maximum frequencies are determined by the emulated chip characteristics, while the emulator maximum frequency is 42MHz. # TRACE AND LOGIC ANALYZER The 32 KByte trace memory is used to record the microprocessor activities. Eight lines are user selectable test points. Trigger inputs and conditions are available for starting and stopping the trace recording. The trace buffer can be viewed in disassembled instructions or high level language lines embedded with the related instructions. #### ITEMS SUPPLIED AS STANDARD In-circuit emulator with 64 KByte breakpoints, 128 KByte internal code memory. Personality probe C51 for 8051 microcontrollers. User software including Source Level Debugger, On-line Assembler and Disassembler. User's Manual and Operating Instructions. RS-232 cable. Power supply. #### **OPTIONS** Personality probes for the different microcontrollers. Memory bank setup. Adapter for 44-pin PLCC devices. #### PERFORMANCE ANALYZER This useful function checks the software trace buffer and provides time statistics on modules and procedures as a percentage of the total execution time. #### **COMMAND SET** The available functions include: FILE (load, save), VIEW (watches, variables, module, cpu, dump, registers, trace, file), RUN (run, go, trace into, step over, execute, animate, halt, reset), BREAKPOINTS (toggle, expression true global, hardware breakpoint, delete all), DATA (inspect, evaluate, add watch), OPTIONS (environment, path, communications, architecture, mode, save, load), WINDOW (zoom, next, size, move, close), HELP (index, previous topic). #### **INPUT POWER** 5VDC/1.5A. #### **MECHANICAL DIMENSIONS** 26mm x 151mm x 195mm (1" x 6" x 7"). CEIBO TI TEL: 314-830-4084 #### **:EIBO DS-51 In-Circuit Emulator** #### **RACE CAPABILITIES** xternal Trace Start/Stop Triggers )S-51 has two External Trigger signals that allow starting and stopping of the trace recording upon external vents. **Stop Trace when Full or Continuous Recording Mode** here are two trace recording modes: Cyclic and Trace Full. In the Cyclic Mode the trace is continuously filled with recorded data. In the Full Mode recording stops when trace is full. Selectable Trace Trigger Levels he trigger state permits selecting the way trigger signals behave. The active mode may be either level or edge for the external start and stop trigger signals. Frace Status on the Fly Frace Status allows viewing information without stopping emulation. The Trace Status includes buffer full, buffer empty, length, etc. **Frace Filtering on Address Ranges** Jp to 10 different ranges are allowed to filter the recorded data into the trace memory. The start and stop addresses of modules and procedures can be entered using special prefixes. TEL: 314-830-4084 FAX: 314-8304083 # CEIBO DS-51 In-Circuit Emulator # **BREAKPOINT OPTIONS** # **Breakpoint on Data Read/Write and Address** Real-time Hardware Breakpoints can be set on Data Read, Data Write, Data Read or Write and Opcode Fetc in any address range. # **Stop Emulation on Pass Count** Pass Count on any event including opcode may be specified by the number of occurences. #### **Breakpoint on External Events** Trace Testpoints may be used as external Breakpoints on Hardware events if enabled. The External Breakpoint triggers may also be the Trace Full condition, then program execution will stop once it is full The Logic Operator commands allow selection of AND/OR combinations of the two external breakpoints. The options are both low, any one is low, both are high, only one is high, both are leading edge, etc. CEIBO TEL: 314-830-4084 #### CEIBO DS-51 In-Circuit Emulator #### **ABOUT THE DEBUGGER** **Environment** C51D is a menu-driven program supplied with DS-51. This debugger runs either under DOS or Windows. C51D Debugger is used to load a program, execute it in real-time or simulate the software environment and nany other functions. **Fracing** A program may be executed one line at a time. You can trace a program using high-level language lines or assembly instructions. Stepping This is like tracing but program execution steps over CALL instructions without leaving the current procedure. Viewing C51D Debugger allows special windows to be opened showing your program state from various perspectives: variables and their values, breakpoints, a text file, a source file, CPU registers, memory, peripheral registers, etc. Inspecting The debugger can delve deeper into your program and show you the variable contents. Changing The current value of a variable can be replaced with your specified value. Watching Program variables can be isolated and their values kept track of while the program runs. **Global Menus** A Global Menu is the list of commands easily accessible from a bar which runs along the top of the screen. A pull-down menu is available for each item on the menu bar and allows the following: - Execute a command. - Open a pop-up menu. Pop-up menus appear when a menu item is chosen followed by a menu icon - Open a dialog box. Dialog boxes appear when a menu item is chosen followed by a dialog box icon (...). Global menus are accessed by pressing F10 and using the arrow keys or typing the first letter of the menu name. Their contents never change. Some of the menu commands have hot key shortcuts that are available from any part of the C51D Debugger. TEL: 314-830-4084 #### **Local Menus** C51D Debugger is context-sensitive and uses Local Menus specifying different windows. Local menus are tailored to the particular window you are in. It is important not to confuse them with global menus. To prompt a local menu press Alt-F10 or click the right button of your mouse. Menu placement and contents depends on which window or pane you are in and where your cursor is. Contents may vary from one local menu to another. Many local commands appear in almost all local menus. The results of these similarly-named commands may differ, depending on the context. Every command on a local menu has a hot key shortcut consisting of Ctrl plus the highlighted letter in the command. Because of this setup, a hot key, like Ctrl-S might mean one thing in one context but something quite different in another. The core commands are still consistent across local menus. For example, the Goto command and the Search command always do the same thing, even when they are invoked from different windows. #### Input boxes Many of the C51D Debugger command options are available in input boxes. An input box prompts you to type in a string, i.e. the name of a file. #### Windows C51D Debugger displays all information and data in both global and local menus, dialog boxes (where options are set and information entered) and windows. There are many window types depending on the kind of information it holds. Windows may be opened and closed using menu commands (or hot key shortcuts for those commands). Most of the Debugger windows come from the View menu. After a window has been opened, you can move, resize, close, and otherwise manage them with commands from the Window and System menus. CEIBO TEL: 314-830-4084 # **CEIBO DS-51 In-Circuit Emulator** # **VARRANTY** WO-YEAR WARRANTY ON ALL CEIBO PRODUCTS. # **ADDRESSES** For more information contact us today: Foll Free (U.S.A. and Canada) 1-800-833-4084 Compuserve 100274,2131 | CEIBO USA | CEIBO ISRAEL | |----------------------|-------------------------------| | TEL: 314-830-4084 | TEL: 972-9-555387 | | FAX: 314-830-4083 | FAX: 972-9-553297 | | 7 EDGESTONE CT. | MERKAZIM BLDG., 5 MASKIT ST | | FLORISSANT, MO 63033 | P.O. BOX 2106, HERZELIA 46120 | | CEIBO SPAIN | CEIBO DEUTSCHLAND | | TEL: 91-5774296 | TEL: 06151-27505 | | FAX: 91-5764966 | FAX: 06151-28540 | | HERMOSILLA 31 | RHEINSTRASSE 32 | | MADRID 28001 | 64283 DARMSTADT | | FRANCE | TEL: 062-072954 | FAX: 062-072953 | |-------------------------------|-------------------|-------------------| | HOLLAND | TEL: 05427-33333 | FAX: 05427-33888 | | ITALY | TEL: 051-727252 | FAX: 051-727515 | | KOREA | TEL: 02-786-5456 | FAX: 02-786-5458 | | | TEL: 74-46873 | FAX: 74-45971 | | SINGAPORE | | FAX: 011-8872051 | | S.AFRICA | TEL: 011-8877879 | | | SWEDEN | TEL: 0589-19250 | FAX: 0589-16153 | | TAIWAN | TEL: 02-9171873 | FAX: 02-9126641 | | OTHER COUNTRIES | TEL: 972-9-561535 | FAX: 972-9-553297 | | • · · · = · · · · · · · · = · | | | **Ordering Information** Part No. : CEIBO DS-51 Product and Company names are trademarks of their respective organizations **CEIBO** TEL: 314-830-4084 # CEIBO DS-300 Peripheral Development Tools Development Tools for PSD-3xx Devices # **FEATURES** - Emulates PSD-3xx Devices - Reads from and Writes to Memories - 1024 Kbits of Emulated EPROM - 16Kbits of Emulated SRAM - 19 Programmable I/O ports - Full DPLD Emulation - Supports 8 and 16 Bus Bits - Configuration Software for Windows - Software for Programming PSD-3xx - Serially Linked to IBM PC at 115KBaud **CEIBO** TEL: 314-830-4084 # CEIBO DS-300 Peripheral Development Tool DS-300 is a complete software and hardware development tool hat allows file generation and emulation of the PSD-3xx devices. The configuration software provides all the elements necessary os set the device with minimum learning time. Memories, I/O ports, bus width and the DPLD are easily setup in a graphic environment that runs under the Windows Operating System. The emulator provides an immediate way to check that the devices are properly configured and allows examination and modification of the memories, and I/O lines. The system emulates PSD-3xx memories. The EPROM is up to 1024 Kbits and the SRAM 16KBits. As the EPROM is emulated by the SRAM device, memory contents may be examined and modified without generating a new file. #### **SPECIFICATIONS** #### SYSTEM MEMORY DS-300 provides 16KBits of SRAM and 1024 Kbits of EPROM overlay memory. This memory may be configured according to all the possibilities of PSD-3xx devices. The EPROM is emulated by a RAM memory, thus allowing to download and modify its contents. #### **I/O PORTS** The emulator supports 19 I/O ports that may be individually used as a microcontroller I/O port expansion, programmable address decoder or latched address output. The outputs can be selected as open drain or CMOS. #### **BUS WIDTH** DS-300 allows configuration of memories as 8 or 16 bit wide. The emulator may be used with any microcontroller supported by the PSD-3xx devices. #### PROGRAMMABLE ARRAYS Two programmable arrays, PAD A and PAD B, are fully emulated by DS-300. A total of 40 product terms and up to 16 inputs and 24 outputs are set by the downloaded file and may be modified by the integrated software environment. #### **BUS SIGNALS** DS-300 includes address latches for multiplexed address/data bus, supports non-multiplexed address/data bus mode, allows definition of ALE and Reset polarity and permits the selection of read and write signals as RD/WR or R/W/E. #### TRACK MODE The emulator supports the address/data track mode, that enables an easy interface to shared resources with other microcontrollers or a host processor. #### **CONFIGURATION SOFTWARE** DS-300 includes a configuration software that runs under Windows Operating Systems. The software integrates the configuration of the device, communications with the DS-300 emulator and with the CEIBO MP-51 programmer. The software menus are: FILE, VIEW, COMPILE, OPTIONS, WINDOW, EMULATOR, PROGRAMMER and HELP. #### **FILE MENU** The file menu allows file downloading and saving and also defines the printer setup. The format is compatible to other existing file generators and programs. The file may be displayed in graphics mode showing the chip configuration and memory contents in hex format. #### **VIEW MENU** The view menu is used for a graphic representation of the chip and allows the setup change just by placing the cursor on the selected variables and clicking the options. The additional memory map screen may be used to define and display the chip selects graphically. #### **COMPILE MENU** The selected chip options may be compiled and the resulting file can be saved for future debugging purposes or for programming the device. #### **EMULATOR MENU** This menu is used to interact with the hardware through the DS-300 emulator. The different emulation options are used for downloading a file, resetting the device and selecting many hardware possibilities. #### **PROGRAMMER MENU** The software is prepared to communicate with the CEIBO MP-51 programmer. The integrated environment makes it possible to program the devices after finishing the debugging and during production. #### INPUT POWER 5VDC from external power supply or from the target circuitry. #### ITEMS SUPPLIED AS STANDARD Emulation header, 44-pin PLCC male connector, user and configuration software, User's Manual and RS-232 interface cable. # **Ordering Information** Part No. CEIBO DS-300 Product and Company names are trademarks of their respective organizations. CEIBO TEL: 314-830-4084 FAX: 314-8304083 # CEIBO DS-750 Microcontroller Development Tool Development Tool for 87C750 Microcontrollers # **FEATURES** - Emulates 87C750 Microcontrollers in Real-Time - Programmable Clock up to 40MHz - Built-in Programmer for 87C750/1/2 - Simulator Debug Mode - Source-Level Debugger for C, PLM and Assembler - DOS and Windows Software - 24-pin DIP Emulation Header - Serially linked to IBM PC at 115 KBaud # CEIBO DS-750 Microcontroller Development Tool DS-750 is a development tool that supports Philips 87C750 microcontrollers at any frequency allowed by the devices. It is serially linked to a PC/XT/AT or compatible system and can emulate the microcontroller using either the built-in clock oscillator or any other clock source connected to the microcontroller. The clock oscillator generates 40MHz, 20MHz, 16MHz, 10MHz and 5MHz. Emulation is carried out by programming an 87C752 microcontroller with the user software and an embedded monitor program. DS-750 provides the onboard programming capabilities and locates the monitor in the upper 1K that is not available for the 87C750. Two working modes are available: real-time and simulator debug mode. In the real time mode the user software is executed transparently and without interfering with the microcontroller speed. Breakpoints can be added to stop program execution at a specific address. In the simulator debug mode, an additional microcontroller is used to take control of the 87C750 lines and to simulate its operation but not in real-time. This operating mode allows access to all the microcontroller functions (I/O, timers, interrupts, etc.) and interacts with the hardware according to the user software execution or directly by means of emulator commands sent from the host computer. The combination of the two available working modes allows an easy way to debug hardware and software functions. The software includes C and PLM and Assembler Source Level Debugger, On-line Assembler and Disassembler, Software Trace, Conditional Breakpoints and many other features. Two versions of the software are available: DOS and Windows. The system is supplied with a User's Manual, microcontroller documentation, two samples of the 87C752 and one of the 87C750 (all windowed EPROM microcontrollers) and a power supply. # **SPECIFICATIONS** #### MONITOR PROGRAM The Monitor Program links the microcontroller to the host computer and is used to control the emulation of the application software in real time. The monitor code is transparent for the 87C750 and does not reduce the 1KByte of available code for the application. #### BREAKPOINTS Breakpoints allow real-time program execution until an opcode is executed at a specified address. Breakpoints are set when an EPROM device is programmed with a user's code, but can be disabled although disabling a breakpoint implies adding a few cycles to the program execution. #### **USER SOFTWARE** DS-750 program has two software environments: DOS and Windows 3.X. The DOS program is based on pull-down menus. The additional Windows program carries out the same functions of the DOS program with all the features and benefits of the new operating system. # SOURCE LEVEL DEBUGGER The DS-750 software includes a source level debugger for Assembler and High-Level Languages (PLM, C and others) with the capability of executing lines of the program while displaying the state of any variable. # SOFTWARE TRACE Program execution can be recorded in a 64K buffer. Conditional breakpoints may be defined to stop program execution. The user can define events and variables to be added to the software trace. The software trace is not a real-time function and is performed by slowing down the emulation speed. #### FREQUENCY The system includes a crystal oscillator able to supply clock frequencies of 5MHz, 10MHz, 16MHz, 20MHz and 40 MHz. Additionally, the user may select any other frequency by connecting an external clock source through the application hardware. Frequency selection is done by means of jumpers. #### SIMULATOR DEBUG MODE The simulator allows breakpoints to be set at any address and condition even though the user software is actually programmed in the 87C752 EPROM. The simulator debug mode will be automatically activated in case a breakpoint is enabled and not programmed in the device. # **BUILT-IN PROGRAMMER** The built-in programmer may be used to program the following devices: 87C750, 87C751 and 87C752. All the programming features like security and encryption are fully supported. # **EMULATION RESTRICTIONS** The following restrictions are valid for DS-750: 1. The system uses some of the microcontroller resources to emulate it: one interrupt (either INT0 or INT1 according to software selection) and 5 bytes of the internal stack. 2. If you specify a breakpoint not programmed in the device, program execution will be slowed down by the simulator. 3. Disabling a programmed breakpoint will add a few cycles to the program execution. This only happens while reaching the specified condition, otherwise the real time is not affected. #### INPUT POWER 15V to 18VDC (15 VDC/120 VAC wall transformer supplied). # **MECHANICAL DIMENSIONS** 10cm x 10cm. # ITEMS SUPPLIED AS STANDARD Development System with built-in programmer. 24-pin emulation header. User software including source level debugger, on-line assembler and disassembler. User's Manual and Operating Instructions. RS-232 interface cable. Power supply. # **Ordering Information** # Part No. P750EM SD Available through Philips distributors. 110V- 12NC:9351-504-20112 220V- 12NC:9351-622-50112 Product and Company names are trademarks of their respective organizations. # CEIBO DS-752 Microcontroller Develpoment Tool Development Tool for 8XC750/1/2 Microcontrollers # **FEATURES** - Real-time and Transparent In-Circuit Emulator - Supports Philips 83C750/1/2 and 87C750/1/2 Microcontrollers - Symbolic Debugger Compatible with Intel Object Files - Source-Level Debugger for C, PLM and Assembler - 2K Hardware Breakpoints and Conditional Breakpoints - 2K of Internal Memory - 64K Software Trace - Serially Linked to PC and Compatible Hosts - On-line Assembler and Disassembler - Easy to Follow Pull-Down Menus and Windows # CEIBO DS-752 Microcontroller Development Tool Ds-752 is a real time, high peformance microcontroller development system dedicated to the 8XC750/1/2 single-chip microcontrollers. It provides an easy to use and flexible instrument which reduces the development and debugging cycle and enables the user to solve hardware and software problems quickly and efficiently. It operates with a PC or compatible computer and carries out complete real-time and transparent emulation of the target CPU. # **SPECIFICATIONS** # **EMULATION MEMORY** DS-752 provides 2 KBytes of code memory. #### HARDWARE BREAKPOINTS Up to 2,048 hardware breakpoints allow real-time program execution until an opcode is executed at a specified address or line of your source code. #### CONDITIONAL BREAKPOINTS A complete set of conditional breakpoints permits halting program emulation on code addresses, source code lines, access to on-chip memory, port and register contents. #### SOFTWARE ANALYZER A 64 KByte buffer is used to record any software and hardware events of your program, such as executed code, memory accesses, port and internal register states, on-chip data memory and others. The trace buffer can be viewed in disassembled symbolics or high level language source code. #### SYMBOLIC DEBUGGER DS-752 allows symbolic debugging of assembler or high-level languages. The symbolic debugger uses predefined port and register names, and the symbols contained in your software, like labels, variable names line numbers and others. # SOURCE LEVEL DEBUGGER DS-752 gives full support for debugging directly in PLM and C source code. From your source code screen you can specify a breakpoint, execute a line step or an assembly instruction, open a flexible-in-size watch window to display any variable, use the function keys to display the trace memory, registers and data, redefine the Program Counter, and reset the microprocessor. #### LANGUAGES AND FILE FORMATS DS-752 accepts files generated by Intel software (Assembler, PLM) or compatibles in hex or object format. Other assemblers and high-level languages such as C with Intel compatible format (Franklin, IAR, etc.) are also supported. ## **PERSONALITY ADAPTERS** DS-752 uses standard microcontrollers for hardware and software emulation. The selection of a different microcontroller is made by software commands and using a supplied socket adapter. The systems run at the frequency of the crystal on them or from the clock source supplied by the user hardware. Therefore, the same system may be adapted to your frequency requirements. The minimum frequency is determined by the emulated chip characteristics, while maximum frequency for standard systems is 16MHz. #### SUPPORTED DEVICES | 83C748. | 87C748, | |---------|---------| | 83C749. | 87C749, | | 83C750. | 87C750, | | 83C751. | 87C751, | | 83C752. | 87C752. | #### **COMMAND SET** The available functions include: FILE (load, save), DEBUG (go, halt, reset, source level debugger, breakpoints), MODIFY (code, byte, registers, ports, assembler, disassembler), VIEW (watch window, publics, modules, procedures, lines, symbols, file, dir), ANALYZER (conditional breakpoints, software trace, event watch), SETUP (default, chip, base, rs-232 port). #### INPUT POWER 7.5VDC to 12VDC or 5VDC from the user circuit. #### **MECHANICAL DEMENSIONS** 1" x 5" x 6" (2.4 cm x 13 cm x 15 cm). # ITEMS SUPPLIED AS STANDARD In-Circuit Emulator with 2 KByte Breakpoints, 2 KByte Internal Code Memory. Personality adpater for 24 pin DIP Microcontrollers. User Software including Source Level Debugger, On-line Assembler and Disassembler. User's Manual and Operating Instructions. RS-232 Interface Cable. 9 VDC wall transformer is not included. # Ordering Information # Part No. P752EM SD Available through Philips distributors. 12NC: 9350-554-10602 Product and Company names are trademarks of their respective organizations. # CEIBO EB-51 Emulation Board EB-51 is an emulation board dedicated to all Philips 80C51 microcontroller derivatives with a 40 or higher pin count. It is serially linked to a PC/XT/AT or compatible systems and can emulate the microcontroller using either the built-in clock oscillator or any other clock source connected to the microcontroller. The clock oscillator generates 24MHz, 16MHz, 12MHz and 6MHz. The system emulates the microcontroller in both ROMless and ROMed mode. A special emulation technology is used to recreate port 0 and 2 with standard devices, releasing most of the microcontroller resources to the user. A two microcontroller architecture leaves the serial port for user applications. The software includes a Source Level Debugger for C, PLM and Assembler, On-line Assembler and Disassembler, Software Trace, Conditional Breakpoints and many other features. All the Debugger functions run under DOS and Windows operating systems. The code memory permits downloading and modifying of user's programs. Mapping the 64KByte data memory to a target circuit or to the system is possible. Breakpoints allow real time execution until an opcode is executed at a specified address or line of the source code. All I/O lines are easily accessed and may be connected to the on-board switches and LEDs when trying out a specific idea. The system is supplied with a User's Manual, software, emulation cable and a power supply. # **SPECIFICATIONS** #### SYSTEM MEMORY EB-51 provides 64K of user code memory and 64K of user data memory. This RAM memory permits downloading and modifying of user's programs and variables. #### **CODE MEMORY** The system includes 64KBytes of RAM to be used as code memory. The upper 2KBytes of this memory are not available for programs and they are automatically loaded with a monitor program which links the microcontroller to the host computer and controls the emulation of the application software in real-time. #### **DATA MEMORY** Data memory is accessed by MOVX instructions and can be mapped as belonging to the system or to the target circuitry. #### **BREAKPOINTS** Breakpoints allow real-time program execution until an opcode is executed at a specified address. # **SOFTWARE TRACE** Program execution can be recorded in a 64K buffer. Conditional breakpoints may be defined to stop program execution. The user can define events and variables to be added to the software trace. The software trace is not a real-time function and is performed by slowing down the emulation speed. #### **USER SOFTWARE** EB-51 software has two software environments: DOS and Windows 3.X. The DOS is based on pull-down menus. The additional Windows program carries out the same functions as the DOS program with all the features and benefits of the new operating system. # SOURCE LEVEL DEBUGGER The EB-51 software includes a source level debugger for assembler and high level languages (PLM, C and others) with the capability of executing lines of the program while displaying the state of any variable. # **FREQUENCY** The system includes a crystal oscillator able to support clock frequencies of 24MHz, 16MHz, 12Mhz and 6MHz. The operating frequency range is from the microcontroller fmin to fmax in ROMless mode. The fmax in ROMed mode is 20MHz. #### SIMULATION DEBUG MODE The simulation debug mode allows the software to be tested without any hardware. All the emulation functions are supported by this powerful simulation debugger. #### **VOLTAGE** The system has a built-in voltage regulator that permits selection of either a 5V or a 3.3V voltage supply. Selection is done by setting the position of the power switch to the desired voltage. #### PERSONALITY ADAPTERS EB-51 uses standard microcontrollers for hardware and software emulation. The selection of a different microcontroller is made by replacing the microcontroller on the board with the appropriate microcontroller or a daughter board. # SUPPORTED MICROCONTROLLERS The supported microcontrollers are most of the Philips 80C51 derivatives in both ROMless and ROMed versions. The required microcontroller on the board and supported devices are: | MICROCONTROLLER | SUPPORTED DEVICES | |-----------------|------------------------------| | 80C32 or 87C52 | 8031/2, 80C51/2/4/8, | | 87C51FB | 87C51/2/4/8<br>8xC51FA/FB/FC | | 87C528 | 8xC524, 8xC528 | | 87C504 | 8xC504 | | 87C550 | 8xC550 | | 87C654 | 8xC652, 8xC654 | Daughter boards and emulation cables are available for other devices: 8xC552, 8xC562, 8xC575, 8xC576, 8xC592, 8xC598, Consult Ceibo for other supported microcontrollers. # **EMULATION RESTRICTIONS** The following emulation restrictions are valid for EB-51: RD and WR lines may not be used as I/O ports. There are no restrictions while RD and WR are activated by MOVX instructions. The system uses some of the microcontroller resources to emulate it: one interrupt (either INT0 or INT1 according to software selection) and 5 Bytes of the internal stack. #### MECHANICAL DIMENSIONS 13cm x 13cm. ## ITEMS SUPPLIED AS STANDARD Emulation board, 40-pin emulation header, user software including Source Level Debugger, Simulator, Assembler, User's Manual, RS-232 interface cable and power supply. # Ordering Information | Part No. CEIBO EB-51 | | | | |----------------------|--|--|--| | | | | | | | | | | Product and Company names are trademarks of their respective organizations. CEIBO TEL: 314-830-4084 FAX: 314-8304083 # CEIBO EB-51 Emulation Board Development Tool for 80C51 Microcontrollers # **FEATURES** - Emulates 80C51 Microcontrollers and Derivatives - Real-Time Operation up to 40 MHz - 3.3V or 5V Voltage Operation - Simulation Debug Mode - Source-Level Debugger for C, PLM and Assembler - Runs under DOS and Windows Software - Support for ROMless and ROMed Microcontrollers - 64K of Code and 64K of Data Memory - Data Memory with Mapping Capabilities - Performance Analyzer - Real-Time and Conditional Breakpoints - Emulation Header and Signal Testpoints - Serially Linked to IBM PC at 115K Baud CEIBO TEL: 314-830-4084 FAX: 314-8304083 # CEIBO MP-51 Programmer EPROM, Flash, PLD and Microcontroller Programmer # **FEATURES** - EPROM, Flash, PLD and Microcontroller Programmer - Serially Linked to PC or Compatible Host - Programs all the 8051 Microcontrollers - Programs 16-bit Microcontrollers - Supports 24 to 32-pin EPROMs - Programs 32-pin Flash Memories - Programs PLD and PSD Devices - Easy to Follow Windows and Pull-Down Menus - Handles Hex, Binary, Object and JEDEC Files - Programs DIP, QFP, LCC and PLCC Devices - Supports Lock Bits, Encryption Table sand Security Bits # EIBO MP-51 Programmer eibo MP-51 is an EPROM, Flash Memory, PLD and icrocontroller Programmer dedicated to standard 24 to 32n EPROMs, all of the microcontrollers belonging to the 8051 mily, 16-bit microcontrollers, high density PLDs, PSD devices nd flash memories. Its modern design provides a high erformance instrument, which is easy to use and conveniently ized. MP-51 operates with an IBM PC/XT/AT or compatible ersonal computer and carries out a set of powerful functions n the selected device. An RS-232 interface is used to link 1P-51 to a PC. The unit consists of the instrument and dapters. The adapters may be replaced to suit the user's equirements. Adapters are available for all the possible ackages such as DIP, LCC, PLCC and QFP. MP-51 software andles a PC Memory Buffer where code is loaded from a lisk or filled with the contents of a device. Furthermore, this ruffer may be saved on a disk file, parts of the buffer can be noved from one location to another, filled with a constant, or nodified by the user. The Memory Buffer can be displayed, and finding values or strings in it is possible. Before programming, MP-81 checks if the installed adapter is compatible with the device type selected by the user. This test s done before programming any device. MP-51 has the capability to check if the device is totally erased, and can also compare if the contents of the plugged device are equal to the contents of the Memory Buffer. Address range can be specified or both operations. MP-51 allows the PLD or Microcontroller security capabilities to be enabled or disabled and handles the Lock Bit 1, Lock Bit 2, Lock Bit 3 and the Encryption Table available in several Microcontrollers. # **SPECIFICATIONS** ## SUPPORTED DEVICES Following is a partial list of supported devices: **EPROMs:** 2716, 2732, 2764, 27128, 27256, 27512, 27010, 27020, 27040, both NMOS and CMOS versions for all the available programming voltages. FLASH MEMORIES: 28F256, 28F512, 28F010, 28F020. 8-BIT MICROCONTROLLERS: 3755A, 8751H, 8751BH, 87551, 87C51FA, 87C51FB, 87C51FC, 87L51FA, 87L51FB, 87C52, 87C54, 87C58, 87C134, 87C451, 87C504, 87C524, 87C528, 87C550, 87C552, 87C575, 87C576, 87C592, 87C598, 87C652, 87C654, 87C748, 87C749, 87C750, 87C751, 87C752, 87C054-MTV, 87C055-MTV, 89C558, 89C559, 87C598, 87C654, 87C748, 87C749, 87C750, 87C751, 87C752, 87C054-MTV, 87C055-MTV, 89C558, 89C559, 87C654, 87C748, 87C759, PLDs: AT22V10, ATV750, ATV2500, ATV5000, ATV5100. **PSDs:** PSD301, PSD301L, PSD302, PSD302L, PSD303, PSD303L, PSD311, PSD311L, PSD312, PSD312L, PSD313, PSD313L. **FILE FORMATS** MP-51 loads different file formats: Intel Hex and Motorola Srecords, Binary files ,Object files, JEDEC files. It saves portions of memory in Intel, Motorola, Binary and JEDEC formats. **USER SOFTWARE** The MP-51 commands are organized in pull-down menus and windows. This software is powerful yet extremely user friendly. **COMMAND SET** The available functions include: TYPE, BLANK CHECK, SECURITY, PROGRAM, LOAD, SAVE, READ, VIEW, COMPARE, CHECKSUM, FILE, MOVE, MODIFY, DIRECTORY, TEXT FILE, DUMP, QUIT. INPUT POWER 85VAC to 265VAC, 50Hz to 60Hz. That makes this unit suitable for any country outlet. # MECHANICAL DIMENSIONS MP-51 is 155mm long, 60mm high and 250mm wide. # ITEMS SUPPLIED AS STANDARD MP-51 Programmer, User software, User's Manual, RS-232 cable. PMP-51 Includes PPA-51X (87C5ID-40 pin DIP adapter). Power cord not included. # ADAPTERS AND SUPPORTED DEVICES The following list shows which adapter should be used for the different supported devices. | and the first section is a second section of the second section of the second section is a second section of the second section of the second section | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADAPTER | SUPPORTED DEVICES | | EPROMs and Flash Memories:<br>27512D - 28 PIN DIP<br>27512P - 32 PIN PLCC<br>27040D - 32 PIN DIP<br>27040P - 32 PIN PLCC | 2716 to 27512 NMOS and CMOS<br>2764 to 27512 NMOS and CMOS.<br>27010 to 27040, 28F256, 28F512,<br>28F010, 28F020.<br>27010 to 27040, 28F256, 28F512,<br>28F010, 28F020. | | | 28F010, 28F020. | | 8-Bit Microcontrollers:<br>87C51D - 40 PIN DIP | 8751H, 8751BH, 87C51, 87C51FA,<br>87L51FA, 87C51FB, 87L51FB,<br>87C51FC, 87C52, 87C54, 87C58,<br>87C504, 87C524, 87C528, 87C550,<br>87C652, 87C654. | | 87C51P - 44 PIN PLCC | 8751H, 8751BH, 87C51, 87C51FA,<br>87L51FA, 87C51FB, 87L51FB,<br>87C51FC, 87C52, 87C54, 87C58,<br>87C504, 87C524, 87C528, 87C652,<br>87C654, AT89C51. | | 87C51Q - 44 PIN QFP | 870534, A189051.<br>87051, 87051FA, 87L51FA, 87C51FB,<br>87L51FB, 87C51FC, 87C52, 87C54,<br>87C58, 87C504, 87C524, 87C528,<br>87C652, 87C654, | | 87CL134D - 42 PIN SHRINK DIP<br>87CL134Q - 44 PIN QFP<br>87C451D - 64 PIN DIP<br>87C451D - 68 PIN PLCC<br>87C550P - 44 PIN PLCC | 87CL134.<br>87CL134.<br>87C451.<br>87C451, 87C453.<br>87C550.<br>87C552. | | 87C552P - 68 PIN PLCC<br>87C575D - 40 PIN DIP | 87C575, 87C576, 87C51, 87C51FA,<br>87L51FA, 87C51FB, 87L51FB,<br>87C51FC, 87C52, 87C54, 87C58,<br>87C504, 87C524, 87C528, 87C652,<br>87C654, | | 87C592P - 68 PIN PLCC<br>87C598Q - 80 PIN OFP<br>87C751D - 24 PIN SKINNY DIP<br>87C751P - 28 PIN PLCC<br>87C752D - 28 PIN DIP<br>87C752P - 28 PIN PLCC<br>87C054D - 42 PIN SHRINK DIP<br>3755AD - 28 PIN DIP<br>3755AD - 28 PIN DIP<br>3755AQ - 32 PIN SO | 87C592.<br>87C598, 89C558, 89C559.<br>87C748, 87C750, 87C751.<br>87C748, 87C750, 87C751.<br>87C749, 87C752.<br>87C749, 87C752.<br>87C054-MTV, 87C055-MTV.<br>PCD3755A.<br>PCD3755A. | | PSDs:<br>PSD301P - 44 PIN PLCC | PSD301, PSD301L, PSD302, PSD302L,<br>PSD303, PSD303L, PSD311, PSD311L,<br>PSD312, PSD312L, PSD313, PSD313L. | Consult Ceibo or Philips for ordering information code (12NC or PPA number in US). # **Ordering Information** # Part No. PMP-51 SD/OM4260 Available through Philips distributors. 12NC: 9350-410-00112 Product and Company names are trademarks of their respective organizations. ice MASTER PRINTER OF # PRODUCT DESCRIPTION The unique iceMASTER-PE packs an advanced feature set into a tiny, palm-sized package that any engineer can afford. Designed for demanding projects, iceMASTER-PE supports frequencies up to 42 MHz with a full complement of emulation memory, external data memory, and a transparent trace buffer 16K frames deep with advanced searching capabilities. The entire emulator plugs directly into the target application or operates in a stand-alone mode. The iceMASTER-PE is the world's most portable emulator because the emulator and probe electronics are both integrated into a pocket-able package about the size of a PC mouse. To achieve this dramatic breakthrough in the size and cost of high-performance emulation, MetaLink invented a new emulation system architecture, Advanced Emulator Technology (AET, patent pending). The iceMASTER-PE's windowed user interface delivers the highest development productivity and is easy to learn and easy to use, including a context-sensitive hypertext and hyperlinked help system. This powerful, productive interface gives the user total control and flexibility in the configuration of the size, position, content, and color of each window The iceMASTER-PE includes a full symbolic and sourcelevel debugger for Assemblers and Compilers. The emulator supports all 9 of the most popular 8051 Assemblers and Compilers. The iceMASTER-PE sets the new standard for excellence, portability and value in 8051 family emulation. - ☐ Supports 8051 family devices up to 42MHz - □ Support for 8031, 8051, 8x32, 8x52, 8xC54, 8xC58, 8xC51FA, 8xC51FB, 8xC51FC, 8xC751, 8xC752, 8xC750, NMOS, CMOS, ROM, EPROM/OTP Devices. - ☐ Full-Featured, Real-time & Transparent Emulator - ☐ Emulator and Probe electronics integrated into a single package only 3" x 4" x 1" - Plugs directly into target applications or operates in a stand-alone mode - ☐ Patent-pending AET system architecture # HARDWARE CAPABILITIES - ☐ Up to 64K Program & 64K External Data Memory - ☐ 16K frame trace buffer - ☐ View trace while executing - ☐ Up to 128K hardware breakpoints - ☐ Up to 64K Trace ON & 64K Trace OFF triggers - ☐ Integrated diagnostic self-test capability # SYSTEM FEATURES - PC-hosted via RS-232 serial link - ☐ Efficient, powerful, easy to learn - ☐ User control of window size, content & color - ☐ Supports third party Assemblers & Compilers - ☐ Full Symbolic & Source-Level debug - ☐ Complete system includes Emulator, 8051 Macro Cross Assembler, RS-232 cable & power supply **AetaLink Corporation** 25 E. Elliot Road Chandler, AZ 85225 Phone: Phone: Fax: (602) 926-1198 (602) 926-0797 (800) 638-2423 MetaLink Europe GmbH 8011 Kirchseeon-Eglharting Fax: Germany Phone: 08091 2046 08091 2386 <sup>3</sup>1993 MetaLink Corporation 1042-001/692/TP # FLEXIBLE, EASY-TO-USE INTERFACE iceMASTER has an advanced, windowed user interface that emphasizes ease of use. Each window can be sized, moved, highlighted, scrolled, color-controlled, added, or removed completely. iceMASTER provides pull-down and pop-up menus, function keys, and context-sensitive help. The contents of any memory space may be perused and altered directly from the appropriate window using the keyboard or a mouse. You have immediate access to the hypertext/hype linked, context-sensitive, on-line help system which clearly explains what your options are (at any detail level you choose), keeping you productive. There is even a HELP-FOR-HELP feature. Whether you are beginning your first design project, or are a veteran designer searching for the fastest possible debugging method, you will appreciate the EASE-OF-USE features designed into iceMASTER. Novices can navigate smoothly through a debugging session by accessing the commands and menus as standard pull-downs. Experienced designers can instantaneously pop-up their menu of choice by using redefinable hot keys. # **DECREASED DEVELOPMENT TIME** Your iceMASTER source window accelerates the debugging process with Dynamically Annotated Code. When single-stepping, instruction execution information is displayed and retained next to each instruction. You can clearly see the data behind your program's flow, including contents of all accessed (read or write) memory locations and registers, as well as flow-of-control direction change markers. A moving color bar indicates the current position in the program as it executes. At your option, the iceMASTER source window allows operations on three different views of code memory: disassembled instructions, instructions mixed with High Level Language (HLL) source statements, or HLL source only. HLL source statements and symbolic disassembly information are also displayed when you disassemble the program or view the trace buffer. # THE COMPLETE DEBUGGER The trace buffer captures data in real-time. Trace information consists of address and data bus values and user-selectable probe clips. You can view the trace buffer data through several display filters: raw hex, disassembled instructions, instructions mixed with HLL source statements, or HLL source only. You can display the probe clip bit values in binary, hex, or digital waveform formats. You can trigger the trace to begin capturing data on all instructions leading up to a breakpoint, around (before and after) a breakpoint, or following a breakpoint. Capture filtering allows you to focus attention only on areas of interest, eliminating clutter. To further speed your design process, an integrated search mechanism allows you to locate any label, HLL source line number, or address in the trace buffer in either the backward or forward direction. The days of manually scanning or post-processing a large buffer of trace data are gone! If you WRITE your program in a HLL, you should be able to DEBUG it that way – iceMASTER lets you do just that! # IMPROVING THE QUALITY OF YOUR PRODUCT: FINDING THE HOT (OR NOT SO HOT) SPOTS iceMASTER emulators (Model 400 & PE) provide a PERFORMANCE ANALYZER that allows you to monitor the time spent executing specific portions of your program to find "hot spots" or "dead code." You can define and analyze memory areas based on code address, module, line number or label ranges. You can view results dynamically during emulation or later for a more detailed analysis. You can toggle the display from bar graph format to actual frequency counts, and you can filter the level of detail in the displayed results to include raw data, code labels, and/or HLL source statements. iceMASTER Model 400 provides an additional Performance Analyzer that is the absolute best in the industry for tuning and testing your code. It is very flexible and far more accurate than most other emulators, with a resolution of less than six microseconds. You can define and analyze up to 15 memory areas and each of these 15 memory areas can consist of non-contiguous, logically related subranges, (e.g. groupings of related functions which are not necessarily contiguous in memory). # FINDING THAT BUG You have access to as many as 128K breakpoints and 64K tracetriggers. These triggers can be enabled, disabled, set or cleared. Simple triggers are based on code or external data addresses or address ranges. Simple breakpoints can be set or cleared directly in the source window at disassembled instructions or HLL source statements. Breakpoints can also be complex triggers, based on code address, direct address, bit address, opcode value, opcode class or immediate operand. Complex triggers can be ANDed and ORed together. Finding that elusive bug is now much easier! # **SMALL AND POWERFUL** Some companies design emulators that use one or two full size PC expansion board slots. These companies take it for granted that you have the "right" kind of PC, that you don't need the expansion slots for something else, and that you don't mind taking apart your computer to install their emulator! At MetaLink, we don't take our customers for granted. The iceMASTER family is the culmination of over 7 years of focused engineering by MetaLink to bring advanced semiconductor technologies to emulator design. Using state-of-the-art PALs (PEELs), LCAs, VLSI memories and microprocessors, MetaLink designed world-class emulation capability into the smallest emulator footprints in the industry, combining powerful and complex emulation features with allaround ease-of-use. The high speed serial link connects easily to the back of your computer with a standard RS-232 cable. The emulators are smaller than the size of a VCR tape, fit neatly in crowded work spaces and are easy to move around on the bench or to other computers. PORTABLE PRODUCTIVITY! # iceMASTER-PE Development System MetaLink specializes in enhancing the emulation technology required by EMBEDDED SYSTEMS DESIGNERS. MetaLink has consistently led the industry in emulation technology: The first PC-based 8051 emulator; the first 8052 emulator; the first to offer support for all the unique features of the 8051 family components, such as watchdog-timer, idle modes, power MetaLink is a full-service emulation company. We support our customers over the long term with services such as repair, discounted upgrades, rental units, 10-day trial purchase periods #### and free technical support for applications problems. A network of world-wide sales and service representatives is augmented by a well-trained telemarketing staff at headquarters. HOST SPECIFICATIONS Function/Hot Key Access: Trace Contents consist of: Host IBM PC, XT, AT, 386, 486, PS/2, Laptop, User-assignable for commands 16-bits Address Bus Notebook or compatible system, 640K bytes of User-displayable for quick reference 8-bits Data Bus RAM, Hard Disk Drive, Monochrome or 7-bits External Clips ■ MEMORY OPERATIONS Color Display, with a Standard RS-232 Serial Trace Display Modes: Port. Operating System DOS 2.0 or greater. Emulation Memory: Raw Hex iceMaster-PE Models: 8031 8032 8351FX 83752 □ EMULATOR SOFTWARE Symbolic Program Memory: 64K 64K 64K 2K **SPECIFICATIONS** HLL Source External Data Memory: 64K 64K 64K N/A Mixed File Formats Supported with Symbolic or Mapping Resolution: Source-Level Debugging: External Clips display format: Program: Down to 1-byte Binary data 2500AD, Archimedes, Avocet, BSO/Tasking, Franklin, External Data: Down to 1-byte IAR Systems, Intel OMF, Keil, MCC, Microtec HEX data Program Memory: Research, Motorola 'S' Record, Systronix and Intel Digital waveform Single Line Assembler (full instruction set support) HEX. Trace Buffer Operations: Source/Symbol Support: Disassemble in Code or Source/Code mode Write trace buffer to a disk file Disassembly may be written to a disk file Assembler, BASIC, C and PL/M Languages Search trace buffer for labels & addresses Symbolic or Source-Level Debug: Data Memory: Setting of Breakpoints Internal or External Memory □ PERFORMANCE Fill a block of memory with data Setting of Trace ON/OFF **ANALYZER** Viewing of Trace Buffer Copy a block of data to another area Program profiling capability Viewing of Source Window Display Change a single address data content 7 year duration Viewing of Performance Analyzer Compare any two blocks of addressed data Assembly/Disassembly of Code Display options: Displayed data may be written to a file HLL Structure/Content Display of: Registers/SFRs/Bit Memory: Bar Graph Modules Frequency Count Line Numbers Examine or Modify Scopes Display Modes: Program Variables Program Variables: Raw **HLL Source Lines** EMULATOR HARDWARE Examine or Modify Symbolic Mixed SPECIFICATIONS Up to 999 Bin capacity □ EMULATION CONTROLS iceMASTER-PE MODELS: User-controlled Bin set-up: Reset from Emulator and Go 8031: Supports 8031 and 80C31 By Address By Symbol Reset from Target and Go Operates up to 33MHz By Module By Line Number 40-Lead DIP or optional 44-Lead PLCC Reset Processor Automatic 8032: Supports 8031, 80C31, 8032, 80C32 and Go from current Program Counter □ HELP C501 Go From a new Program Counter Operates up to 42MHz Go Until a Program Counter/Label On-Line 40-Lead DIP or optional 44-Lead PLCC Slow Motion (Repetitive Step commands) Context sensitive 83752: Supports 83C751, 87C751, 83C752, 87C752 Step by machine instruction Hypertext/Hyperlinked and 87C750 Step by Line Number Operates up to 16MHz □ DIAGNOSTIC SELF-TEST Step Over calls 24- & 28-Lead DIP or optional 28-Lead PLCC Step To next function or procedure Determines Emulation Hardware Status 8351FX: Supports 8031, 80C31, 8032, 80C32, 8051, 80C51, 8751, 87C51, 8052, 80C52, 8752, ☐ HARDWARE BREAKPOINTS MACRO 87C52, 80C51FA, 83C51FA, 87C51FA, Up to 64K real-time Program Addresses Repetitive routines 83C51FB, 87C51FB, 83C51FC, 87C51FC, Up to 64K real-time External Data Addresses User-created and callable 80C54, 87C54, 80C58 and 87C58 Operates up to 16MHz TRIGGER CONDITIONS □ ELECTRICAL 40-Lead DIP or optional 44-PLCC Set directly in Source window or Pull-down menu **SPECIFICATIONS** OPERATING CHARACTERISTICS PC address & range of addresses Input Power (maximum): Clock frequency user-selectable between external target Opcode Value 0.75 A @ +5 VDC +/-5% Opcode Class crystal/clock or internal clock source Power Source: Target system or power supply Real-time, Electrically and Operationally Transparent SFRs/Registers Direct byte address & range of addresses □ MECHANICAL **USER INTERFACE** Direct bit address & range of addresses SPECIFICATIONS Keyboard or Mouse Control Immediate operand value Emulator Dimensions: Pull-down & Pop-up menus with fill-in boxes Read/Write to bit address x 3.25" Available Main Screen Windows: 4.4" x 0.9" Register address modes 11.18cm x 8.25cm x 2.29cm Registers and PSW bits Read/Write to Register address Bit Memory Emulator weight: Logical AND/OR of any of the above Stack data displayed in HEX &/or ASCII 0.5lbs 0.3kg External Data address & range of addresses Up to 5 Internal Data Memory displayed in HEX &/or ASCII Break Count Overflow ANNUNCIATORS Up to 5 External Data Memory displayed in HEX &/or ASCII External (CLIP) Break Input Up to 5 Code Memory displayed in HEX &/or ASCII Power and Active LEDs External (CLIP) Trigger Output Source Program displayed in Code, HLL Source or Mixed Power ON/OFF switch Watch window for variable data ☐ TRACE System Status data WARRANTY Real-time trace with view while executing code Main Screen Window Display Controls: One (1) year limited warranty, parts and labor 16K-Frame Trace Buffer Movable Selectable (On/Off) Start, Center, End and Variable Trace Trigger settings Sizable Color selection Scrollable Up to 64K Trace ON/OFF triggers for trace filtering Highlighting of key data Call Today 1(800) 638-2423 1(800) METAICE or contact your local distributor Rental plans are available. # ceMASIFRE # PRODUCT DESCRIPTION The iceMASTER-8051 Model 200/400 emulator represents a culmination of 7 years of focused engineering to create the world's most affordable and portable full-featured emulators. The iceMASTER-8051 emulators offer real-time and transparent emulation at up to 24MHz for a broad number of derivative devices through the use of interchangeable probe cards. Powerful breakpoint systems allow an engineer to stop a program at any time and examine all states and conditions. Trace memory provides a complete history of each event that has occurred, including source-level information, address, data, status, searching and external logic events. The best performance analyzer capability in the industry allows a thorough evaluation of the program to decide what areas are taking the most time and simplify those areas requiring improved performance. The iceMASTER-8051 emulators support symbolic and source-level debugging for the most popular 8051 Cross Assemblers, 'C' Compilers, and PL/M Compilers. These capabilities allow the designer to debug their system the way it was designed, at the symbolic or source-level. This methodology increases productivity while decreasing cost and time-to-market. The iceMASTER-8051 emulators provide pull-down and pop-up menus, mouse support, function/hot keys, and context-sensitive hyperlinked help. The advanced windowed user interface emphasizes ease of use. Each window can be sized, moved, scrolled, highlighted, color-controlled, added or removed completely. The contents of any memory space may be perused and altered directly from the appropriate window, with multiple memory spaces displayable simultaneously. Fax: # KEY CHARACTERISTICS - ☐ Full-Featured, Real-time & Transparent Emulator - ☐ Supports 8051 family devices up to 24MHz - ☐ Interchangeable Probe Cards - ☐ Hosted on any PC or compatible, including Laptops, Notebooks, or Micro Channel - ☐ 115K baud serial link using a standard comm port - ☐ Unlimited user support # HARDWARE CAPABILITIES - ☐ 64K Program & 64K External Data Memory - ☐ 4K frame trace buffer - ☐ Advanced trace search ability - ☐ 128K hardware breakpoints - □ 64K Trace ON/OFF triggers - ☐ Broad 8051 derivative device support (more than 65 devices) - Dual Performance Analyzers # SYSTEM FEATURES - ☐ Efficient, powerful, easy to learn - ☐ User control of window size, content & color - ☐ Supports third party Assemblers & Compilers - ☐ Full Symbolic & Source-Level debug - ☐ Complete system includes Emulator, 8051 Macro Cross Assembler, RS-232 cable & power supply **MetaLink Corporation** 325 E. Elliot Road Chandler, AZ 85225 (602) 926-0797 Phone: Phone: (800) 638-2423 (602) 926-1198 MetaLink Europe GmbH 8011 Kirchseeon-Eglharting Fax: Germany Phone: 08091 2046 08091 2386 ©1992 MetaLink Corporation 1043-000/992/TP # FLEXIBLE, EASY-TO-USE INTERFACE iceMASTER has an advanced, windowed user interface that emphasizes ease of use. Each window can be sized, moved, highlighted, scrolled, color-controlled, added, or removed completely. iceMASTER provides pull-down and pop-up menus, function keys, and context-sensitive help. The contents of any memory space may be perused and altered directly from the appropriate window using the keyboard or a mouse. You have immediate access to the hypertext/hype linked, context-sensitive, on-line help system which clearly explains what your options are (at any detail level you choose), keeping you productive. There is even a HELP-FOR-HELP feature. Whether you are beginning your first design project, or are a veteran designer searching for the fastest possible debugging method, you will appreciate the EASE-OF-USE features designed into iceMASTER. Novices can navigate smoothly through a debugging session by accessing the commands and menus as standard pull-downs. Experienced designers can instantaneously pop-up their menu of choice by using redefinable hot keys. # **DECREASED DEVELOPMENT TIME** Your iceMASTER source window accelerates the debugging process with Dynamically Annotated Code. When single-stepping, instruction execution information is displayed and retained next to each instruction. You can clearly see the data behind your program's flow, including contents of all accessed (read or write) memory locations and registers, as well as flow-of-control direction change markers. A moving color bar indicates the current position in the program as it executes. At your option, the iceMASTER source window allows operations on three different views of code memory: disassembled instructions, instructions mixed with High Level Language (HLL) source statements, or HLL source only. HLL source statements and symbolic disassembly information are also displayed when you disassemble the program or view the trace buffer. # THE COMPLETE DEBUGGER The trace buffer captures data in real-time. Trace information consists of address and data bus values and user-selectable probe clips. You can view the trace buffer data through several display filters: raw hex, disassembled instructions, instructions mixed with HLL source statements, or HLL source only. You can display the probe clip bit values in binary, hex, or digital waveform formats. You can trigger the trace to begin capturing data on all instructions leading up to a breakpoint, around (before and after) a breakpoint, or following a breakpoint. Capture filtering allows you to focus attention only on areas of interest, eliminating clutter. To further speed your design process, an integrated search mechanism allows you to locate any label, HLL source line number, or address in the trace buffer in either the backward or forward direction. The days of manually scanning or post-processing a large buffer of trace data are gone! If you WRITE your program in a HLL, you should be able to DEBUG it that way – iceMASTER lets you do just that! # IMPROVING THE QUALITY OF YOUR PRODUCT: FINDING THE HOT (OR NOT SO HOT) SPOTS iceMASTER emulators (Model 400 & PE) provide a PERFORMANCE ANALYZER that allows you to monitor the time spent executing specific portions of your program to find "hot spots" or "dead code." You can define and analyze memory areas based on code address, module, line number or label ranges. You can view results dynamically during emulation or later for a more detailed analysis. You can toggle the display from bar graph format to actual frequency counts, and you can filter the level of detail in the displayed results to include raw data, code labels, and/or HLL source statements. iceMASTER Model 400 provides an additional Performance Analyzer that is the absolute best in the industry for tuning and testing your code. It is very flexible and far more accurate than most other emulators, with a resolution of less than six microseconds. You can define and analyze up to 15 memory areas and each of these 15 memory areas can consist of non-contiguous, logically related subranges, (e.g. groupings of related functions which are not necessarily contiguous in memory). # FINDING THAT BUG You have access to as many as 128K breakpoints and 64K tracetriggers. These triggers can be enabled, disabled, set or cleared. Simple triggers are based on code or external data addresses or address ranges. Simple breakpoints can be set or cleared directly in the source window at disassembled instructions or HLL source statements. Breakpoints can also be complex triggers, based on code address, direct address, bit address, opcode value, opcode class or immediate operand. Complex triggers can be ANDed and ORed together. Finding that elusive bug is now much easier! # **SMALL AND POWERFUL** Some companies design emulators that use one or two full size PC expansion board slots. These companies take it for granted that you have the "right" kind of PC, that you don't need the expansion slots for something else, and that you don't mind taking apart your computer to install their emulator! At MetaLink, we don't take our customers for granted. The iceMASTER family is the culmination of over 7 years of focused engineering by MetaLink to bring advanced semiconductor technologies to emulator design. Using state-of-the-art PALs (PEELs), LCAs, VLSI memories and microprocessors, MetaLink designed world-class emulation capability into the smallest emulator footprints in the industry, combining powerful and complex emulation features with all-around ease-of-use. The high speed serial link connects easily to the back of your computer with a standard RS-232 cable. The emulators are smaller than the size of a VCR tape, fit neatly in crowded work spaces and are easy to move around on the bench or to other computers. PORTABLE PRODUCTIVITY! # ceMASTER-8051 Model 200/400 Development Systems MetaLink specializes in enhancing the emulation technology required by EMBEDDED SYSTEMS DESIGNERS. MetaLink has consistently led the industry in emulation technology: he first PC-based 8051 emulator; the first 8052 emulator; the first to offer support for all the unique features of the 8051 family components, such as watchdog-timer, idle modes, power own mode, DMA and A/D. MetaLink is a full-service emulation company. We support our customers over the long term with services such as repair, discounted upgrades, rental units, 10-day trial purchase periods, nd free technical support for applications problems. A network of world-wide sales and service representatives is augmented by a well-trained telemarketing staff at headquarters. # HOST SPECIFICATIONS Host IBM PC, XT, AT, 386, 486, PS/2, Laptop, Notebook or compatible system, 640K bytes of RAM, Hard Disk Drive, Monochrome or Color/Graphic Display, with a Standard RS-232 Serial Port. Operating System DOS 2.0 or greater. # **EMULATOR SOFTWARE SPECIFICATIONS** File Formats Supported with Symbolic or Source-Level Debugging: Archimedes, Avocet, BSO/Tasking, Franklin, IAR Systems, Intel OMF, Keil, MCC, Microtec Research, Motorola 'S' records and Intel HEX. Source/Symbol Support: Assembler, C and PL/M Languages Symbolic or Source-Level Debug: Setting of Breakpoints Setting of Trace ON/OFF Viewing the Trace Buffer Viewing of Source Window Display Viewing of Performance Analyzer Assembly/Disassembly of Code HLL Structure/Content Display of: Line Numbers Modules Program Variables # □ EMULATOR HARDWARE **SPECIFICATIONS** iceMASTER-8051 Models: 200 Basic Emulator 400 Enhanced Emulator with: 4K Trace Buffer 2 Performance Analyzers Full Watchdog Timer Support Operating Modes: Single-Chip ROM Romless Interchangeable Probe Card Used to support the functional derivatives of each micro controller family as well as the full range of NMOS, CMOS, EPROM, and OTP technology variations. Contact MetaLink for the latest information on any device supported. Device Unique Support A-to-D Converter Multiple-Divide Unit Multiple DPTRs # OPERATING CHARACTERISTICS Clock frequency user-selectable between external target crystal/clock or internal crystal source Electrically and Operationally Transparent Real-time: 0.5-24MHz #### USER INTERFACE Keyboard or Mouse Control Pull-down & Pop-up menus with fill-in boxes Available Main Screen Windows: Registers and PSW bits Bit Memory Stack data displayed in HEX &/or ASCII Up to 5 Internal Data Memory diplayed in HEX &/or ASCII Up to 5 External Data Memory displayed in HEX &/or ASCII Up to 5 Code Memory displayed in HEX &/or ASCII Source Program displayed in Code, HLL Source or Mixed Watch window for variable data System Status data displayed in HEX Main Screen Window Display Controls: Movable Sizable Selectable (On/Off) Color selection Scrollable Highlighting of key data Function/Hot Key Access: User-assignable for commands User-displayable for quick reference # ☐ MEMORY OPERATIONS **Emulation Memory:** 64K Program Memory 64K External Data Memory Mapping Resolution: 16-bytes/block Program: External Data: 16-bytes/block Program Memory: Single Line Assembler (full instruction set support) Disassemble in Code or Source/Code mode Disassembly may be written to a disk file Data Memory: Internal or External Memory Fill of a block of memory with data Copy a block of data to another area Change a single address data content Compare any two blocks of addressed data Displayed data may be written to a file Registers/SFRs/Bit Memory: Examine or Modify Program Variables: Examine or Modify # ■ EMULATION CONTROLS Reset from Emulator and Go Reset from Target and Go Reset Processor Go from current Program Counter Go From a new Program Counter Go Until a Program Counter/Label Slow Motion (Repetitive Step commands) Step by machine instruction Step by Line Number Step Over calls Step To next function or procedure # □ HARDWARE BREAKPOINTS 64K real-time Program Addresses 64K real-time External Data Addresses # □ TRIGGER CONDITIONS Set directly in Source window or Pull-down menu PC address & range of addresses Opcode Value Opcode Class SFRs/Registers Direct byte address & range of addresses Direct bit address & range of addresses Immediate operand value Read/Write to bit address Register address modes Read/Write to Register address Logical AND/OR of any of the above External Data address & range of addresses Break Count Overflow External (CLIP) Break Input External (CLIP) Trigger Output 807 # ☐ TRACE (Model 400) 4K-Frame Trace Buffer Start, Center, End & Variable Trace Trigger settings 64K Trace ON/OFF triggers for trace filtering Trace Contents consist of: 16-bits Address Bus 8-bits Data Bus 7-bits External Clips **DMA** Activity Trace Display Modes: Raw Hex Symbolic HLL Source Mixed External Clips display format: Binary data HEX data Digital waveform Trace Buffer Operations: Write trace buffer to a disk file Search trace buffer for labels & addresses # □ PERFORMANCE ANALYZERS (Model 400) Real-time Program profiling capability 5.4u-sec sampling period 7 year duration Display options: Bar Graph Frequency Count Display Modes: Symbolic Raw **HLL Source Lines** Mixed Up to 999 Bin capacity User-controlled Bin set-up: By Address By Symbol By Line Number By Module # Automatic □ HELP On-Line Context sensitive Hypertext/Hyperlinked # □ MACRO Repetitive routines User-created and callable # □ ELECTRICAL **SPECIFICATIONS** Input Power (maximum): 1.5 A @ +5 VDC +/-5% # □ MECHANICAL SPECIFICATIONS Emulator Dimensions: x 5.5" 7.0" 17.8cm x 14cm x 2.54cm Emulator weight: 2.0lbs # □ ANNUNCIATORS Power, Reset, Break, and Active LEDs Power ON/OFF, Reset, Break switches # □ WARRANTY One (1) year limited warranty, parts and labor Call Today 1(800) 638-2423 1(800) METAICE or contact your local distributor Rental plans are available. Product names are used to purposes of identification only and may be trademarks or registered trademarks of their respective companies. # Ordering Information # Philips Semiconductors 8051 Family Microcontroller Support # iceMASTER-PE Emulators The iceMASTER-PE emulators for the 8051 family are self-contained units, each dedicated to a particular member of the 8051 family. The emulator and probe card electronics are combined into a single, small package. Every iceMASTER-PE emulator comes with 64K of Code memory, 64K of External Data memory, a 16K frame Trace Buffer (which can be viewed without breaking emulation), power supply, RS-232 cable and an 8051 Macro Cross Assembler. All iceMASTER-PE emulators support an optional Break-Input signal clip, a Trigger-Output signal clip and seven user-placeable Trace-Capture-Input signal clips. The following iceMASTER-PE emulators are currently available: # PE-8031-33 This emulator supports device operation from DC to 33MHz and has a 40-lead DIP footprint. This emulator supports the 8031 and 80C31 devices, regardless of process variation. #### PW-8032-30 This emulator supports device operation from DC to 30MHz and has a 40-lead DIP footprint. This emulator supports the 8031, 80C31, 8032 and 80C32 devices, regardless of process variation. # PE-83752-16 This emulator supports device operation from DC to 16MHz and has a 28-lead DIP footprint. This emulator supports the 83C750, 87C750, 83C751, 87C751, 83C752 and 87C752 devices, regardless of process variation. This emulator is supplied with a 28-lead DIP to 24-lead DIP converter (CONV11) for 8xC751 support. ## PE-8351FX This emulator supports device operation from DC to 16MHz and has a 40-lead DIP footprint. This emulator supports the 8031, 80C31, 8032, 80C32, 80C31, 80C51, 80C51, 80C51, 80C52, 80C52, 87C52, 87C52, 8xC51FX, 80C54, 87C54, 80C58 and 87C58, regardless of process variation. The following iceMASTER-PE emulators will be available in Q2'94. # PE-87L51FB This emulator supports device operation from 3.5 to 16MHz and has a 40-lead DIP footprint. This emulator supports the 87L51FB device from 3.0 to 5.5 volts. # PE-8XCL410 This emulator supports device operation from 0.5 to 16MHz and has a 40-lead DIP footprint. This emulator supports the 83CL410 and 80CL410 devices from 1.8 to 6 volts. #### PE-80CL51 This emulator supports device operation from 32kHz to 16MHz and has a 40-lead DIP footprint. This emulator supports the 80CL51 and 80CL31 devices from 1.8 to 6 volts. (602) 926-0797 FAX: (602) 926-1198 # iceMASTER Model 200 & Model 400 Emulators All iceMASTER Model 200 & Model 400 emulators support full probe card interchangeability. To emulate several different devices, you need purchase only a single emulator base unit, the iceMASTER-8051, and then one probe card for each unique device to be emulated. Both the iceMASTER-8051 Model 200 and the iceMASTER-8051 Model 400 emulators come with 64K of Code memory and 64K of External Data memory, power supply, RS-232 cable and an 8051 Macro Cross Assembler. The IceMASTER Model 400 emulator has the following additional features/capabilities: - 7. 4K-Frame Trace Buffer - 8. Performance Analyzers - a. High Resolution - b. High Bin Count - 9. Full Watchdog Timer (WDT) Support in all emulation modes # **Philips Semiconductors 8051 Family Probe Cards** All MetaLink probe cards include a Break-Input signal clip, a Trigger-Output signal clip and seven user-placeable Trace-Capture-Input signal clips. In addition, there is a user-selectable jumper for XTAL source. Most probe cards have other user-selectable jumpers to control/configure the unique capabilities of each particular device. Some probe cards also contain a user-selectable jumper for $V_{CC}$ source. iceMASTER-8051 emulators fully supports: All I/O ports, with no restrictions. The CMOS Idle and Power Down modes of operation, in those devices having such capabilities. The Watchdog Timer (WDT), in those devices having such a capability. (iceMASTER-8051 Model 400 only) Correct device interconnection footprints. Following is a list of all Philips Semiconductors 8051 Family Probe Cards which MetaLink currently offers. Since MetaLink is constantly adding to its list of supported devices, please contact MetaLink for information on any device not listed below. If support for a particular device is available at different maximum frequencies (MHz), the description of the Probe Card appears only once, with the speed variations noted in the Probe Card names above the description. Example: 8031-24 for a 24MHz 8031 Probe Card and 8031-20 for a 20MHz 8031 Probe Card. # MHW-8031-20 MHW-8031-24 The 8031 Probe Card supports device operation from 0.5 to 24MHz and has a 40-lead DIP package interface. This probe card supports 8031 and 80C31 devices, regardless of process variation. #### MHW-8032-20 The 8032 Probe Card supports device operation from 0.5 to 20MHz and has a 40-lead DIP package interface. This probe card supports 8031, 80C31, 80C32, 80C32 and 80C32 devices, regardless of process variation. (602) 926-0797 FAX: (602) 926-1198 # MHW-80C51FA-16 The 80C51FA Probe Card supports device operation from 0.5 to 16MHz and has a 40-lead DIP package interface. This probe card supports 8031, 80C31, 8032, 80C51FA and 80C32 devices, regardless of process variation. #### MHW-83C51FX-16 The 83C51FC Probe Card supports device operation from 0.5 to 16MHz and has either a 40-lead DIP or a 44-lead PLCC package interface. This probe card supports 8031, 80C31, 80C32, 80C32, 80C51, 80C51, 8751, 87C51, 8x51FA, 8x51FB, 8052, 80C52, 8752 and 87C52 devices, regardless of process variation. # MHW-8052-16 The 8052 Probe Card supports device operation from 0.5 to 16MHz and has a 40-lead DIP package interface. This probe card supports 8031, 80C31, 8032, 80C32, 8051, 80C51, 8052, 80C52, 8751, 87C51, 87C51, 87C52, and 87C52 devices, regardless of process variation. # MHW-83C053-12 The 83C053 Probe Card supports device operation from 6 to 12MHz and has a 42-lead Shrink DIP package interface. This probe card supports 83C053, 83C054, 87C054, 83C055 and 87C055 devices, regardless of process variation. # MHW-80CL410-12 The 80CL410 Probe Card supports device operation from 0.5 to 12MHz and has a 40-lead DIP package interface. This probe card supports the 80CL410 device (4.5V-5.5V only). #### MHW-80C451-16 The 80C451 Probe Card supports device operation from 1.2 to 16MHZ and has a 68-lead PLCC package interface. This probe card supports the 80C451 device, regardless of process variation. Converter #5 is available to convert the probe card to a 64-lead DIP footprint. #### MHW-83C451-12 The 83C451 Probe Card supports device operation from 1.2 to 12MHz and has a 68-lead PLCC package interface. This probe card supports the 80C451, 83C451 and 87C451 devices, regardless of process variation. Converter #5 is available to convert the probe card to a 64-lead DIP footprint. # MHW-80C528-16 The 80C528 Probe Card supports device operation from 1.2 to 16MHz and has a 40-lead DIP package interface. This probe card supports the 80C528 device. # MHW-83C528-12 MHW-83C528-16 The 83C528 Probe Card supports device operation from 1.2 to 16MHz and has either a 40-lead DIP or 44-lead PLCC package interface. This probe card supports 80C528, 83C528, 87C528, 83C524 and 87C524 devices, regardless of process variation. ## MHW-83C550-12 The 83C550 Probe Card supports device operation from 1.2 to 12MHz and has a 44-lead PLCC package interface. This probe card supports the 83C550, 80C550 and 87C550 devices, regardless of process variation. #### MHW-80C552-16 The 80C552 Probe Card supports device operation from 1.2 to 16MHz and has a 68-lead PLCC package interface. This probe card supports the 80C552 and 80C562 devices, regardless of process variation. Converter #7 is available to convert the probe card interface to a 40-lead DIP footprint for operation as an 8031, 8032, 80C31, 80C32 or 80C652. #### MHW-83C552-16 The 83C552 Probe Card supports device operation from 1.2 to 16MHz and has a 68-lead PLCC package interface. This probe card supports the 80C552, 83C552, 87C552, 80C562, 83C562 and 87C562 devices, regardless of process variation. Converter #7 is available to convert the probe card interface to a 40-lead DIP footprint for operation as an 8031, 8032, 80C31, 80C32, 8x51, 8xC51, 8x52, 8xC52, 8xC652 or 8xC654. # MHW-83C575-16 The 83C575 Probe Card supports device operation from 0.5 to 16MHz and has either a 40-lead DIP or a 44-lead PLCC package interface. This Probe Card supports 80C575, 83C575 and 87C575 devices, regardless of process variation. #### MHW-83C592-16 The 83C592 Probe Card supports device operation form 1.2 to 16MHz and has a 68-lead PLCC package interface. This probe card supports the 80C592, 83C592 and 87C592 devices, regardless of process variation. #### MHW-80C652-16 The 80C652 Probe Card supports device operation from 1.2 to 16MHz and has a 40-lead DIP package interface. This probe card supports 8031, 80C31 and 80C652 devices from any IC manufacturer, regardless of process variation. ## MHW-83C652-16 The 83C652 Probe Card supports device operation from 1.2 to 16MHz and has a 40-lead DIP package interface. This probe card supports 80C652, 83C652 and 87C652 devices from any IC manufacturer, regardless of process variation. ### MHW-83C654-16 The 83C654 Probe Card supports device operation from 1.2 to 16MHz and has a 40-lead DIP package interface. This probe card supports 80C652, 83C654 and 87C654 devices from any IC manufacturer, regardless of process variation. #### MHW-83C751-16 The 83C751 Probe Card supports device operation from 0.5 to 16MHz and has a 24-lead Skinny DIP package interface. This probe card supports 83C751 and 87C751 devices, regardless of process variation. # MHW-83C752-12 The 83C752 Probe Card supports device operation from 0.5 to 12MHz and has a 28-lead DIP package interface. This probe card supports 83C752 and 87C752 devices, regardless of process variation. #### MHW-80C851-12 The 80C851 Probe Card supports device operation from 1.2 to 12MHz and has a 40-lead DIP package interface. This probe card supports 8031, 80C31, and 80C851 devices, regardless of process variation. #### MHW-83C851-12 The 83C851 Probe Card supports device operation from 1.2 to 12MHz and has a 40-lead DIP package interface. This probe card supports 80C851, and 83C851 devices, regardless of process variation. # iceMASTER Converters iceMASTER converters are used with the iceMASTER-8051 Probe Card to allow the user to change the device footprint supported by the Probe Card to new device footprint or to allow the iceMASTER-8051 Probe Card to support a new device with the existing Probe Card. #### MHW-CONV5 A 68-lead PLCC to 64-lead DIP converter for 83C451 or 80C451 Probe Cards to 80C451, 83C451 and 87C451 devices. # MHW-CONV7 A 68-lead PLCC to 40-lead DIP converter for 83C552 or 80C552 Probe Cards to 8031, 8032\*, 80C31, 80C32\*, 8051, 8751, 80C51, 87C51, 8052\*, 8752\*, 80C52\*, 80C652, 83C652, 87C652, 87C654, 83C654 and 87C52\* devices. \*Not all modes of Timer 2 supported. # MHW-CONV11 A 28-lead DIP to 24-lead DIP converter for the PE-83752 or 83C752 Probe Card to 83C751 and 87C751 devices. # MHW-CONV12 A 24-lead Skinny DIP to 28-lead PLCC converter for 83C751 Probe Card to 83C751 and 87C751 devices. # MHW-CONV13 A 28-lead DIP to 28-lead PLCC converter for PE-83752 and 83C752 Probe Card to 83C752 and 87C752 devices. #### MHW-CONV14 A 40-lead DIP to 44-lead PLCC converter for PE-8031, 8031 Probe Card to 8031, 80C31, 80C31 and 80C31 devices. A 40-lead DIP to 44-lead PLCC converter for PE-8032, 8032 Probe Card to 8031, 80C31, 80C31, 80C31, 80C32, 8032 and 80C32 devices. A 40-lead DIP to 44-lead PLCC converter for 8052 Probe Card to 8031, 80C31, 80C31, 80C31, 80C32, 80C32, 8051, 80C51, 8751, 87C51, 8052, 80C52, 8752 and 87C52 devices. A 40-lead DIP to 44-lead PLCC converter for 8351FB Probe Card to 8031, 80C31, 80C31, 80C31, 80C32, 80C32, 8051, 80C51, 8751, 87C51, 8052, 80C52, 8752, 87C52, 8XC51FA and 8XC51FB devices. A 40-lead DIP to 44-lead PLCC converter for 80410 Probe Card to 80CL410 devices. A 40-lead DIP to 44-lead PLCC converter for 80652 and 83652 Probe Cards to 80C652, 87C652, 83C652, 87C654 and 83C654 devices. A 40-lead DIP to 44-lead PLCC converter for 80528 and 83528 Probe Cards to 80C528, 87C528, 83C528, 87C524 and 83C524 devices. A 40-lead DIP to 44-lead PLCC converter for 80851 and 83851 Probe Cards to 80C851 and 83C851 devices. #### MHW-CONV19 A 68-lead PLCC to 44-lead PLCC converter for 83552 and 80552 Probe Cards to 8031, 8032\*, 80C31, 80C32\*, 8051, 8751, 80C51, 87C51, 8052\*, 8752\*, 80C52\*, 80C652, 83C652, 87C652, 87C654, 83C654 and 87C52\* devices. #### MHW-CONV23 A 44-lead PLCC to 40-lead DIP converter for 80550 Probe Card to 80C550, 87C550 and 83C550 devices. # iceMASTER-8051 and PE Hardware Miscellaneous Products #### MHW-EXT24DIP A 24-lead Skinny DIP, 6 inch target interface extension cable for 83C751 and 87C751 devices. # MHW-EXT28DIP A 28-lead DIP, 6 inch target interface extension cable for 83C752 and 87C752 devices. #### MHW-EXT40DIP A 40-lead DIP, 6 inch target interface extension cable for 8031, 80C31, 8032, 80C32, 8051, 80C51, 8751, 87C51, 8051FA, 83C51FA, 87C51FA, 8051FB, 83C51FB, 87C51FB, 8052, 80C52, 8752, 87C52, 80C528, 83C528, 87C528, 83C524, 87C524, 80C652, 83C652, 87C652, 83C654, 87C654, 80CL410, 80C851 and 83C851 devices. #### MHW-EXT28PLCC A 28-lead PLCC, 6 inch target interface extension cable for 83C751, 87C751, 83C752 and 87C752 devices. #### MHW-EXT44PLCC A 44-lead PLCC, 6 inch target interface extension cable for 8031, 80C31, 8032, 80C32, 8051, 80C51, 8751, 87C51, 8051FA, 83C51FA, 87C51FA, 8051FB, 83C51FB, 87C51FB, 8052, 80C52, 8752, 87C52, 80C528, 83C528, 87C528, 83C524, 80C550, 83C550, 87C550, 80C652, 83C652, 87C652, 83C654, 87C654, 80CL410, 80C851 and 83C851 devices. #### MHW-EXT68PLCC A 68-lead PLCC 6 inch target interface extension cable for 83C552, 87C552, 83C562, 87C562, 80C552, 83C451, 87C451, 87C592, 80C592 and 83C592 devices. # MHW-DIPSE24/3 A 24-lead Skinny DIP pin isolator for 83C751 and 87C751 devices. # MHW-DIPSE28/6 A 28-lead DIP pin isolator for 83C752 and 87C752 devices. # MHW-DIPSE40/6 A 40-lead DIP pin isolator for 8031, 80C31, 80C32, 80C32, 8051, 80C51, 8751, 87C51, 8051FA, 83C51FA, 87C51FA, 8051FB, 83C51FB, 87C51FB, 8052, 80C52, 8752, 87C52, 80C528, 83C528, 87C528, 83C524, 87C524, 80C550, 83C550, 87C550, 80C652, 83C652, 87C652, 83C654, 87C654, 80CL410, 80C851 and 83C851 devices. # MHW-DIPSE42S/6 A 42-lead Shrink DIP pin isolator for 87C054, 83C054 and 83C053 devices. # **MHW-PLECSE28** A 28-lead PLCC pin isolator for 83C751, 87C751, 83C752 and 87C752 devices. #### **MHW-PLECSE44** A 44-lead PLCC pin isolator for 8031, 8032, 80C32, 8051, 80C51, 8751, 87C51, 8051FA, 83C51FA, 87C51FA, 8051FB, 83C51FB, 87C51FB, 8052, 80C52, 87C52, 87C52, 80C528, 83C528, 87C528, 83C524, 87C524, 80C550, 87C550, 87C550, 80C652, 83C652, 87C652, 83C654, 87C654, 80CL410, 80C851 and 83C851 devices. #### MHW-PLECSE68 A 68-lead PLCC pin isolator for 83C552, 87C552, 83C562, 87C562, 80C552, 83C451, 87C451, 80C451, 87C592, 80C592 and 83C592 devices. # iceMASTER-8051 and PE Software Miscellaneous Products # MSW-ASM51 MetaLink 8051 Macro Cross Assembler ## MSW-SIM51 Archimedes Software SimCASE 8051 for PC-hosted systems # MSW-SIMI/O51 Archimedes Software Sim I/O 8051 for PC-hosted systems #### MSW-A51 Archimedes Software Assembler 8051 for PC-hosted systems # MSW-C51 Archimedes Software 8051 Family C Compiler for PC-hosted systems (602) 926-0797 FAX: (602) 926-1198 # MSW-AVA51 Avocet Systems, Inc. AvCase Assembler for the 8051 #### MSW-AVC51 Avocet Systems, Inc. AvCase C-Compiler and Assembler for the 8051 # MSW-AVS51 Avocet Systems, Inc. AvCase Simulator for the 8051 #### MSW-BSO/A51 BSO/Tasking Assembler 8051 for PC-hosted systems # MSW-BSO/C51 BSO/Tasking C-Compiler and Assembler for 8051 for PC-hosted systems # MSW-BSO/PLM51 BSO/Tasking PL/M-Compiler and Assembler for 8051 for PC-hosted systems # MSW-F/4010 Franklin Software A51 Assembler for PC-Hosted Systems # MSW-F/5020 Franklin Software C-51 Compiler and A51 Assembler for PC-hosted systems #### MSW-F/8220 Franklin Software 8051 Developer's Kit with C-51 Compiler, A51 Assembler, Simulator/Debugger for PC-hosted systems # MSW-F/8310 Franklin Software 8051 Professional Developer's Kit with C-51 Compiler, A51 Assembler, Bank Linker 51, Tiny Real Time Operating System 8051, Simulator/Debugger for PC-hosted systems # NOHAU EMUL51-PC - PC-based in-circuit emulator # 1.0 System Architecture Features of the Nohau EMUL51-PC in-circuit emulator include: - Low-cost full real-time emulation - IBM PC-bus plug-in boards, or stand alone Box version with 115K baud RS232-C connection to IBM PC - Easy-to-learn user interfaces with windows and pull-down menus - Choice of interfaces: Windows, DOS, ChipView (Borland keypress compatible), other third-party interfaces - Source-level debugging in C, PL/M or Pascal with full support for typed symbols - 256k frames by 64 bit real-time trace option with time stamp - Program Performance Analyzer The Nohau EMUL51-PC consists of a board which plugs directly into the IBM PC/XT/AT bus for fast file transfer. An optional external box with a serial link is also available. The LanICE option supports network workstations. The optional Trace board features an advanced trace function with many trigger capabilities. The POD, which plugs into the target system, is connected with a $5 \, \mathrm{ft} \, (1.5 \, \mathrm{m})$ ribbon cable to the Emulator board to provide a useful operating range. The EMUL51-PC uses no wait states and does not intrude on memory, stack, I/O or interrupt pins. fig 1 EMUL51-PC plug-in board version fig 2 External Box version # 2.0 User Interfaces # 2.1 DOS Interface The user interface is based on MS-DOS software. It incorporates a variety of techniques. The user can select to operate either with short typed commands or using pull-down menus. On-screen features include windows to monitor or alter: - Assembly or high level language source code - CPU registers - Internal data and Special Function Registers - External data - Watch variables in C, PL/M or assembly - Trace setup and display All commands are supported with context-sensitive help and full on-line manual. # 2.2 Windows Interface - Pull-down menus - Speed bar (point and click) - Source Window - Watch Window for high-level variables All the ease and flexibility of Microsoft Windows. # 2.3 ChipView-51 Interface - High Level / Low Level Debugger - Keypress-compatible with Borland's Turbo Debugger - Resizable moveable windows - C call stack - Support all emulator variations # 3.0 Specific Features # 3.1 Source Level Debugging Using high level language for code generation is a way to cut development time. Therefore the EMUL51-PC gives full support for debugging directly in C or PL/M source code. This eliminates the need for paper listings. Breakpoints can be marked directly in the source code window. The user can single step through the program line by line and follow the program execution on the screen listing. The trace permits the user to trace his source code in real-time. All variables can be displayed and altered. This includes full support for typed symbols which permits the user to address such variables as floating-point, arrays and structures — both global and local. # 3.2 Emulation Memory The EMUL51-PC features 64 K of code memory and 64 K of external data memory. The addressable memory can be mapped either to target or to the emulator in 4K pages. The emulator can load all common file formats and the user can view and alter all registers and memory areas of the microcontroller. # 3.3 Breakpoints The EMUL51-PC permits the user to generate program breakpoints in a number of ways: - 64K program breakpoints - 64K data read and 64K data write breakpoints - Break on external signal - Break on direct access to internal bit or byte memory - Break on contents of internal register or memory - Break on program access out-of-boundary Using the Trace board it is possible to break on combinations of address, data, control signals, port signals and external signals. # 3.4 Macros and debug session logging Test session automation is made possible using the Macro commands. This permits the user to define his own command sequences using structures like IF/ELSE and REPEAT/WHILE. Such command sequences can be stored to a file which can be loaded automatically when the emulator is invoked. A complete debug session and all setups can also be recorded to a file. # 3.5 Trace Memory The optional trace board features a trace buffer capable of storing up to 256k frames of 64 bit data each. The 64 bits consist of address, data, control signals, port signals, external signals and a time stamp. The trace memory can be displayed, reprogrammed and restarted during emulation. # 3.5.1 Trace Filter The trace filter makes it possible to select what events are stored in the trace buffer. The qualifiers permit the user to define the criteria for which bus cycles are stored. The qualifiers can specify address, data, control signals, port signals and external signals. # 3.5.2 Trace Trigger The trace works much like a logic analyzer. It is therefore possible to trigger the trace on an event and display what happened before or after that event. The trigger event can be defined using any of the qualifiers in up to eight levels. It is possible to trigger on boolean combinations of the qualifiers, or sequential combinations including a loop counter. The trigger point can be selected anywhere within the 256k trace buffer to give full choice of pre/post trigger alignment. # 3.5.3 Trace Display The trace information can be displayed in high-level language statements, in disassembled form or in binary/hex form. It can also be stored to a file. # 3.5.4 Program Performance Analyzer With the PPA, information can be generated showing which addresses the user program spends its time on. The information can be displayed as statistics or in histogram form. # 4.0 General Specifications Host: IBM PC/XT/AT/386/486, PS/2 or compatible with 640K of RAM. Monochrome, color or enhanced graphics display. External Box: The emulator boards can be installed in an external box with serial communication to the PC. Processors supported: 8051, 8052, 8031, 8032, 80C51, 80CL51, 80C52, 80CL52, 80C31, 80CL31, 80C32, 8XC053/054/055, 83/80CL410/610, 83/80C451, 8XC524, 8XC528, 8XC550, 83/80C552, 8XCE558, 80C562, 8XC575, 80CL580, 8XC592, 8XC598, 83/80C652, 8XC748, 8XC749, 83/87C750, 83/87C751, 83/87C752, 8XCL781, 8XCL782, 83/80C851, 8XC51FA/FB (For more details, please refer to the following pages.) A switch from one microcontroller to another is made by changing the low cost POD. File formats supported: Intel HEX/OBJ/SYM/OMF, Avocet, Archimedes/IAR, BSO/Tasking, Franklin/Keil, Intermetrics/Whitesmiths/Comic, and many more. Clock speed: Allows operation up to 33 MHz in real-time. Power supply: The boards are powered from the PC-bus. The Emulator board requires 1.7A/5V and the Trace board 1.3A/5V. # 5.0 Ordering information # PHILIPS SEMICONDUCTORS Microcontroller Support #### **EMULATOR UNITS** Includes software and ribbon cable. Must be connected to a POD to operate. Each step up in frequency rating covers all lower frequency steps. Includes DIP isolator if ordered with 40-pin POD. Emulator software has high-level debug and all options. | Order Number | Description | |-------------------|----------------------------------------------------| | EMUL51-PC/E32 | 12 MHz Emulator, 32 kB (kiloByte) Emulation Memory | | EMUL51-PC/E32-16 | 16 MHz Emulator, 32 kB Emulation Memory. | | EMUL51-PC/E128 | 12 MHz Emulator, 128 kB Emulation Memory. | | EMUL51-PC/E128-16 | 16 MHz Emulator, 128 kB Emulation Memory. | | EMUL51-PC/E128-20 | 20 MHz Emulator, 128 kB Emulation Memory. | | EMUL51-PC/E128-24 | 24 MHz Emulator, 128 kB Emulation Memory. | | EMUL51-PC/E128-30 | 30 MHz Emulator, 128 kB Emulation Memory. | | EMUL51-PG/E128-33 | 33 MHz Emulator, 128 kB Emulation Memory. | # TRACE BOARD OPTIONS Optional second PC plug-in board. Emulator board contains no trace capability. Each frequency step covers all lower steps. | Order Number | Description | |-------------------|------------------------------------------------| | EMUL51-PC/TR4 | 12 MHz 4 kiloframe (4096 frames) Trace Buffer. | | EMUL51-PC/TR4-16 | 16 MHz 4 k Trace Buffer. | | EMUL51-PC/TR16 | 12 MHz 16 k Trace Buffer. | | EMUL51-PC/TR16-16 | 16 MHz 16 k Trace Buffer. | | EMUL51-PC/TR16-20 | 20 MHz 16 k Trace Buffer. | | EMUL51-PC/TR16-24 | 24 MHz 16 k Trace Buffer. | | EMUL51-PC/TR16-30 | 30 MHz 16 k Trace Buffer. | | EMUL51-PC/TR16-33 | 33 MHz 16 k Trace Buffer. | | | | Advanced Trace Boards feature 32-bit timestamping with 16-bit prescaler, eight-level triggers, state and counter functions, search. | Order Number | Description | |---------------------|-------------------------------------| | EMUL51-PC/ATR64-16 | 16 MHz 64 k Advanced Trace Buffer. | | EMUL51-PC/ATR256-16 | 16 MHz 256 k Advanced Trace Buffer. | | EMUL51-PC/ATR64-24 | 24 MHz 64 k Advanced Trace Buffer. | | EMUL51-PC/ATR256-24 | 24 MHz 256 k Advanced Trace Buffer. | | EMUL51-PC/ATR64-33 | 33 MHz 64 k Advanced Trace Buffer. | | EMUL51-PC/ATR256-30 | 30 MHz 256 k Advanced Trace Buffer. | # BONDOUT PODS, 24-PIN, 40-PIN, 68-PIN, 84-PIN Allow full emulation of internal, external and mixed modes of bus or port input/output. On-board POD crystal is 12 MHz on all PODs of any frequency specification. Each step up in frequency rating covers all lower frequency steps. | Order Number | Description | |--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | POD-C51B | 12 MHz Bondout POD for 80C51, 8051, 87C51, 8751, 80C31, 8031, 80C/83C652, 83C654, 80C/83C662, 80C/83C851 single-chip or external mode. | | POD-C51B-16 | 16 MHz Bondout POD for 80C/87C51-1, 80C/87C51, 80/8751, 80C31-1, 80C31, 8031, 80C/83C652, 83C654, 80C/83C662, 80C/83C851 single-chip or external mode. | | POD-C51B-24 | 24 MHz POD for 80C/87C51-24, 80/8751, 80C31-24, 80C/83C652/654, 80C/83C662, 80C/83C851 single-chip or external mode. <b>Special Requirement:</b> Due to bondout chip timing, this POD requires a 30 MHz emulator board and trace board must be 30 MHz if used. | | POD-CL410 | POD for 83CL410, 83CL610, 80CL31, 80CL51. Target voltage range: 1.5–5.0V. Maximum frequency: 12 MHz at 5.0V. This POD is intended for emulating internal code. External bus operation is limited | | POD-C451B-PGA | 12 MHz Bondout POD for 83C451, 87C451, 80C451 PLCC, single-chip or external mode. PGA from POD. Use optional adapter for PLCC target. | | | 16 MHz Bondout POD for 83C451, 87C451, 80C451 PLCC, single-chip or external mode. PGA from POD. Use optional adapter for PLCC target. | | POD-C552B-PGA | 12 MHz Bondout POD for 83C552, 87C552, 80C552 PLCC, single-chip or external mode. PGA from POD. Use optional adapter for PLCC target. | | | 16 MHz Bondout POD for 83C552, 87C552, 80C552 16 MHz, 12 MHz single-chip or external mode. PGA from POD. Use optional adapter for PLCC target | | POD-C552B-PGA-24 | 24 MHz Bondout POD for 8XC552 or 8XC562 PLCC single-chip or external mode. PGA from POD. Use optional adapter (etc). <b>Special Requirement:</b> Due to bondout chip timing, this POD requires a 30MHz emulator board and trace board must be 30 MHz if used. | | POD-CL580<br>POD-C652B | 12MHz Bondout POD for 83CL580.<br>Order as POD-C51B. | | POD-C751<br>POD-C751-16<br>POD-CL782 | 12 MHz 83C750, 87C750, 83C751, 87C751, DIP POD. Includes EXT-DIP24. 16 MHz 83C750, 87C750, 83C751, 87C751, DIP POD. Includes EXT-DIP24. 12 MHz POD for 83CL781, 83CL782, 83CL52 | | | | # "HOOKS" MODE PODS, 28-PIN, 40-PIN, 42-PIN, 44-PIN, 68-PIN Standard chip operated in special "hooks" emulation mode for single-chip or external modes. Some electrical characteristics are different from microcontroller's. On-board POD crystal is 12 MHz on all PODs of any frequency specification. | Order Number | Description | |----------------------|-------------------------------------------------------------------------------------------------------------------------| | POD-C52 | 12 MHz POD for 80C31, 80C32, 80C51, 80C52, 87C51, 87C52. | | POD-C52-16 | 16 MHz POD for 80C31, 80C32, 80C51, 80C52, 87C51, 87C52. | | POD-L51P-16 | 16 MHz POD for 8XC51FA/FB. | | POD-C528 | 12 MHz POD for 80C528, 83C528, 87C528, 83C524, 83C528. | | POD-C528-16 | 16 MHz POD for 80C528, 83C528, 87C528, 83C524, 83C528 | | POD-C550-PGA | 12 MHz POD for 80C550, 83C550, 87C550, PGA from POD. Use optional adapter for PLCC target | | POD-C550-PGA-16 | 10 MHZ POD for 80C550, 83C550, 87C550, PGA from POD. Use optional adapter for DLCC torrest | | POD-C558-16 | 16 MHz POD for 83CE558/89CE558. Use optional adapter. | | POD-C575 | 12 MHz 87C575, 87C575 chip may have to be supplied by user | | POD-C592-PGA | 12 MHz POD for 8XC592. 8XC592 chip may have to be supplied by user. PGA from POD. Use optional adapter for PLCC target. | | POD-C592-PGA-16 | 16 MHz POD for 8XC592. 8XC592 chip may have to be supplied by user. PGA from POD. Use optional adapter for PLCC target. | | POD-C752 | 12 MHz 83C752, 87C752 DIP POD. Includes EXT-DIP28. | | POD-C752-16 | 16 MHz 83C752, 87C752 DIP POD. Includes EXT-DIP28. | | POD-C054<br>POD-C575 | 12 MHz POD for 8XC053, 8XC054, 8XC055 (Micocontroller-for-Television-Video). 16 MHz POD for 8XC575. | # POD BOARDS, 40 PIN EXTERNAL MODE Port 2 is upper address bus only. Port 0 is address/data bus. P3.6 is WRITE, P3.7 is READ. On-board POD crystal is 12 MHz on all PODs of any frequency specification. Each step up in frequency rating covers all lower frequency steps. | Order Number | Description | |--------------|---------------------| | POD-31 | 12 MHz 8031 POD. | | POD-C31 | 12 MHz 80C31 POD. | | POD-32 | 12 MHz 8032 POD. | | POD-C32 | 12 MHz 80C32 POD. | | POD-C652 | 12 MHz 80C652 POD. | | POD-C31-1 | 16 MHz 80C31-1 POD. | | POD-C32-16 | 16 MHz 80C32 POD. | | POD-C31-20 | 20 MHz 80C31 POD. | | POD-C31-24 | 24 MHz 80C31 POD. | | POD-C31-30 | 30 MHz 80C31 POD. | | POD-C31-33 | 33 MHz 80C31 POD. | -S version of the above boards allows P3.6, P3.7 to be used either as unidirectional I/O or write and read. (Example: POD-31-S; POD-C31-S-1; POD-C32-S-16.) # **EXTERNAL MODE PODS, 64-PIN, 68-PIN** Port 2 is upper address bus only. Port 0 is address/data bus. P3.6 is WRITE, P3.7 is READ. On-board POD crystal is 12 MHz on all PODs of any frequency specification. Each step up in frequency rating covers all lower frequency steps. | <b>Order Number</b> | Description | |---------------------|------------------------------------------------------------------------| | POD-C451-DIP | 12 MHz 80C451 DIP POD. | | POD-C451-DIP-16 | 16 MHz 80C451 DIP POD. | | POD-C451-PGA | 12 MHz 80C451 PLCC POD. PGA from POD. | | POD-C451-PGA-16 | 16 MHz 80C451 PLCC POD. PGA from POD. | | POD-C552-PGA | 12 MHz 80C552 POD. PGA from POD. Use optional adapter for PLCC target. | | POD-C552-PGA-16 | 16 MHz 80C552 POD. PGA from POD. | | POD-C552-PGA-24 | 24 MHz 80C552 POD. PGA from POD. | | POD-C552-PGA-30 | 30 MHz 80C552 POD. PGA from POD. | | POD-C562-PGA-16 | 16 MHz 80C562 POD. PGA from POD. | | 102 000- | | # LanICE LOCAL AREA NETWORK OPTION FOR XWindows (Sun, HP, and other workstations) | Order Number | Description | |--------------|--------------------------------------------------------------------------------------------------------------| | LanICE | XWindows Sun or HP workstation option for TCP/IP networks. Order this LanICE plus any emulator and POD unit. | | | Trace buffer units are optional. The LanICE can accommodate multiple emulators. | # **BOX OPTIONS** Box units are AC line-powered. Emulator software runs under DOS on PC and uses a COM port at 110 baud to 115 kilobaud. Serial cable included. | Order Number | Description | |----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | EMUL51-PC/BOX-S<br>EMUL51-PC/BOX-CS<br>EMUL51-PC/BOX-CS-20<br>EMUL51-PC/BOX-CS-24<br>EMUL51-PC/BOX-CS-30 | Serial Box. Select emulator separately; trace optional. POD not included. Serial Box with E128-16 Emulator and TR16-16 Trace. POD not included. Serial Box with E128-20 Emulator and TR16-20 Trace. POD not included. Serial Box with E128-24 Emulator and TR16-24 Trace. POD not included. Serial Box with E128-30 Emulator and TR16-30 Trace. POD not included. | # MISCELLANEOUS OPTIONS | Order Number | Description | |-----------------------------|-----------------------------------------------------------------------------------------------------| | EMUL51-PC/PRG | Universal Programmer (EPROM, 8751, 87C51, PAL). | | EMUL51-PC/PRG751 | Programmer for 87C751, 87C752. | | PHILIPS/LCPX5X | Single board programmer for DIP parts: 87C750, 'C751 and 'C752; PLCC parts: 87C451 and 'C552. | | PHILIPS/LCPX5X40 | Single board programmer for Philips 87C51, 'C51FA, 'C51FB, 'L51FB, 'C52, 'C524, 'C528, 'C550, | | | 'C575, 'C652 and 'C654 DIP or PLCC. | | EMUL51-PC/EXT-DIP24 | Additional externder cable for 24 pin DIP. | | EMUL51-PC/DIP24-ISO | 24 pin DIP Isolator. | | EMUL51-PC/DIP24-PLCC28 | 24 pin DIP to 28 pin PLCC. | | EMUL51-PC/EXT-DIP24-PLCC28 | Extender cable, 24 pin DIP to 28 pin PLCC. | | EMUL51-PC/EXT-DIP28 | Extender cable, 28 pin DIP. | | EMUL51-PC/DIP28-PLCC28 | 28 pin DIP to 28 pin PLCC. | | EMUL51-PC/DIP28-ISO | Additional 28 pin DIP Isolator. | | EMUL51-PC/DIP28-DIP24-ADAP | 28-pin (0.600-In) to 24-pin (0.300-In) adapter to plug POD-C752 into 8XC751 target. The user is | | | responsible for port and register compatibility. | | EMUL51-PC/EXT-DIP40 | Extender cable for 40 pin DIP. | | EMUL51-PC/DIP40-ISO | Additional 40 pin DIP Isolator. | | EMUL51-PC/DIP40-PLCC44 | 40 pin DIP to 44 pin PLCC. | | EMUL51-PC/DIP40-ONCE-DIP40 | Clips over target microcontroller. Disables target micro to allow emulation without removing target | | | chip. Works only on chips with on-chip emulation (ONCE) disable feature. | | EMUL51-PC/DIP40-ONCE-PLCC44 | Clips over target microcontroller. Disables target micro to allow emulation without removing target | | | chip. Works only on chips with on-chip emulation (ONCE) disable feature. | | EMUL51-PC/PGA44-PLCC44 | PGA to PLCC adapter, 44 pin. | | EMUL51-PC/PGA44-PLCC44-EL2 | PGA to PLCC "elevator" or "tower" rigid 2-inch extender-adapter. | | EMUL51-PC/PGA44-DIP40-C550 | Adapter to use POD-C550-PGA in DIP target. | | EMUL51-PC/EXT-DIP48 | Extender cable for 48 pin DIP. | | EMUL51-PC/DIP48-ISO | 48 pin DIP Isolator. | | EMUL51-PC/PGA68-PLCC68 | PGA to PLCC adapter unit, 68 pin. | | EMUL51-PC/PGA68-DIP84 | PGA to DIP adapter unit for 451 PGA PODs to plug into DIP target. | | EMUL51-PC/PGA68-ISO | 68 pin PGA Isolator. | | QILEXT-1 | Extractor tool for PLCC parts. | | EMUL51-PC/EZ | E-Z-Hook® wires for trace. | | | E-Z-Hook is a registered trademark of Tektest, Inc. | | EMUL51-PC/CBL10-S | 10 foot substitute for 5 foot POD cable (not for bondout PODs). | | EMUL51-PC/CBL10-A | Additional 10 foot POD cable (not for bondout PODs) | | EMUL51-PC/CBL5-A | Replacement 5 foot POD cable | | | | # BANKSWITCH EMULATOR BOARDS User selectable as two banks of 64 kBytes, or as three switchable banks in upper half (8000 - FFFF) with lower half (0000 - 7FFF) not switchable. MOVX read-write data memory is only separate from code if data is mapped to target. | separate from code it data is mapped to target. | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Order Number | Description | | | EMUL51-PC/E128-BSW EMUL51-PC/E128-BSW-16 EMUL51-PC/E128-BSW-24 EMUL51-PC/E128-BSW-33 EMUL51-PC/E256-BSW EMUL51-PC/E256-BSW-16 EMUL51-PC/E256-BSW-24 -BSW option to any POD Examples: | 12 MHz Bankswitch Emulator, 128 kB Emulation Memory. Requires Bankswitch POD. 16 MHz Bankswitch Emulator, 128 kB Emulation Memory. Requires Bankswitch POD. 24 MHz Bankswitch Emulator, 128 kB Emulation Memory. Requires Bankswitch POD. 33 MHz Bankswitch Emulator, 128 kB Emulation Memory. Requires Bankswitch POD. 12 MHz Bankswitch Emulator, 256 kB Emulation Memory. Requires Bankswitch POD. 16 MHz Bankswitch Emulator, 256 kB Emulation Memory. Requires Bankswitch POD. 24 MHz Bankswitch Emulator, 256 kB Emulation Memory. Requires Bankswitch POD. | | | PÔD-31-BSW<br>POD-C31-BSW-1<br>POD-31-S-BSW | 12 MHz 8031 Bankswitch POD.<br>16 MHz 80C31-1 Bankswitch POD.<br>12 MHz 8031 -S option Bankswitch POD. | | #### SOFTWARE PACKAGES Order Number Description **NOHAU Corporation** EMUL51-PC/SWSUB EMUL51-PC emulator software update service, one year. Avocet Systems, Inc. AVOCET/AVA51 Avocet Systems AvCase51 8051 Assembler Avocet is a registered trademark of Avocet Systems, Inc. BSO/Tasking BSOTSK/C51PKG BSOTSK/PLM51PKG BSO/Tasking 8051 Family C-Compiler and Assembler Package. BSO/Tasking 8051 Family PL/M Compiler and Assembler Package. Chip Tools, Inc. Chip Tools Chip View-51 High-Level/Low-Level Debugger Emulator interface for EMUL51-PC. CV51-NOH CV51-S Chip Tools Chip View-51 High-Speed Simulator. CV51-SNOH Chip Tools Chip View-51 CV51-NOH + CV51-S Combo package. Chip Tools and Chip View are trademarks of Chip Tools, Inc. Franklin Software, Inc. Franklin 8051 Macro Assembler with Linker, Librarian, Object-to-Hex utility. FRANKLIN/4020 FRANKLIN/5020 Franklin V4 Very High Performance 8051 Compiler & Assembler. FRANKLIN/7020 Franklin V5 Simulator/Debugger, Windowed Interface. FRANKLIN/8220 Franklin Developers Kit with 5020 Compiler, 4020 Assembler and 7020 Simulator/Debugger. Franklin is a trademark of Franklin Software, Inc. Intermetrics Microsystems Software, Inc./Whitesmiths, Ltd. Intermetrics Whitesmiths C-Compiler and Assembler, Extended. INTERMET/C851HX INTERMET/D851HXNOH Intermetrics Whitesmiths C Source-Level Debugger/Emulator Version (Interface for EMUL51-PC). INTERMET/D851HXSIM Intermetrics Whitesmiths C Source-Level Debugger/Simulator Version. Whitesmiths and CXDB are registered trademarks of Intermetrics, Inc. The EMUL51-PC Emulator, Trace, POD, and Box hardware is sold with a one-year warranty. The EMUL51-PC Emulation software is sold with no warranty, but upgrades will be distributed to all customers up to one year from the date of purchase. Nohau Corporation makes no warranties, express or implied, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. In no event will Nohau Corporation be liable for consequential damages. The SIMUL51-PC Simulator software includes updates for a period of one year. Third-party software and programmers sold by Nohau carry manufacturers' warranties. # CHOOSING PODS for the EMUL51-PC People sometimes ask: "How do I choose which POD to use for the 8051-family chip I want to emulate?" Which POD you pick for your application depends on several things. What micro you are using, the frequency, the mode you are using it in, your target configuration, and price all play a part. The EMUL51-PC ORDER INFORMATION can help you choose among the POD types available from Nohau. Nohau has several categories of PODs: (1) External-mode PODs; (2) Bondout PODs; and (3) "Hooks"-mode PODs. # 1. External-Mode PODs - External or microprocessor-mode PODs have several clear advantages. They are the cheapest type of POD. They have easily-replaceable standard microcontrollers. Your program runs on the real production part, with most of the lines directly connected to your target. You can use them where your microcontroller has external program or external read-write memory. With this type of POD, Port 2 is used only for the upper address bus and not as port input-output (I/O). Port 0 is used as a multiplexed address and data bus. In most of these PODs, P3.6 can only be used as the write line and P3.7 as only the read line. The POD-31 is a typical external POD. - Your target system shares Port 0 and Port 2 with the emulator. The emulator uses Port 0 to run its monitor code when it is not executing your code in real-time. When you are not running real-time emulation, the POD holds the Program Store ENable line (PSEN) high so that your external read-only memory (ROM) is not enabled. It also holds the ReaD/ line and WRite/ lines high so that none of your external read-write random access memory (RAM) or I/O is enabled. - But in the monitor (not emulating) mode, the address lines of both Port 2 and Port 0 are active and can output any address in the 64 kByte address range. It is up to your target system to prevent enabling any device unless the PSEN/ or the RD/ or the WR/ line goes low. - If you are emulating a ROM-less part, like the 8031, you can use the POD-31 type of POD. You also might use this POD for some internal ROM applications. You could use it for designs that have all of Port 2 and Port 0 used as external buses. This is true even though the program can be executed from on-chip 8051 program memory in your final product. This is a case where your target schematic, rather than the device you are using lets you use this type of POD. So though the part may ultimately be an 8051 or 8751, you can use a POD-31 because you are using the ports as buses. - If you are emulating the 80C31, 8032, 80C32 or 80C652, you can get external-mode PODs for these microcontrollers. With the POD-31, you can emulate all those parts in external mode at up to 12 MHz. You can get the POD with the correct micro installed, such as a POD-32. Or you can change among the types by changing the microcontroller component in the POD yourself. - 16 MHz, 20 MHz, 24 MHz, 30 MHz and 33 MHz PODs are available for 40-pin parts. If you use a **POD-C31-1** with a 16 MHz rated emulator, you can support such parts as the 80C31-1, 80C32-1 and 80C652-1. Any higher-frequency POD and emulator set can support all the lower frequencies. - For emulating the 80C451, 80C552, or 80C562 other external mode PODs are available. PODs for dual inline package (DIP) parts have a DIP plug coming out of the bottom of the POD. PODs for plastic leaded chip carrier (PLCC) parts have a pin-grid array (PGA) plug coming out from the bottom of the POD. To plug a PGA POD into a PLCC socket, you can get an optional adapter. The PGA68-PLCC68 is a typical adapter. If your target board has feed-through holes and you solder a PGA socket into it, you don't need an adapter. If your target board already has a PGA socket, you don't need an adapter. - POD-31-S: All the above external PODs use P3.6 as WR/ and P3.7 as RD/. But there is a 40-pin external mode POD version that lets you use these two lines as I/O. The basic board is the POD-31-S. This special -S option lets you select whether the two lines are to be WR/ and RD/ or else I/O. They can be unidirectional port lines (input-input, input-output, output-input, or output-output). You also can get this POD in the variations of 16 MHz and 20 MHz and any of the 40-pin part variations listed above. # 2. Bondout PODs Bondout PODs use special microcontrollers that the semiconductor manufacturers designed to perform all the functions of the part. They also have additional lines "bonded out" from the chip that allow control for emulation. PODs with these special chips cost more than PODs with widely available commercial chips, but give you a greater flexibility in how you use the ports. These PODs allow you to use any combination of internal or external mode of the chip, and respond to the state of the External Access (EA/) pin. Nohau has bondout PODs for many different microcontrollers. You can emulate the 80/80C51, 87/87C51, 80/80C31, 80C/83C/87C652, 83C/87C654, 80C/83C662 and 80C/83C851 with the **POD-C51B**. 16 MHz and 24 MHz versions are available. To emulate the 83C451, 87C451 and 80C451 in the PLCC package, you can use the **POD-C451B-PGA**. See the previous discussion about PGAs. For emulating the 80C/83C/87C552 and 80C/83C/87C562 you can use the **POD-C552B-PGA**. It also is available in a 16 MHz and 24MHz versions. For emulating the 83C750, 87C750, 83C751 and 87C751, use the **POD-C751**. It has a 24 pin DIP plug on the bottom of the POD. You also can get an adapter to plug into 28 pin PLCC sockets. A 16 MHz version is available. For emulating the 8XCL410, 8XCL31, and 8XCL51, use the POD-CL410. For emulating the 83CL580, use the POD-CL580 and a special adapter. For emulating the 83CL781, 87CL781, 83CL782, 87CL782 and 80CL52, use the POD-CL782. You should be aware of one small problem that most 8051 bondout parts have with serial communication. Specifically, if your program has written to SBUF, but the TI flag has not been set, and you then break emulation, the TI flag will never be set after you resume emulation. Bondout PODs give you the best of both worlds. They let you mix how you use the ports. So you can emulate the single-chip mode using the ports as I/O. Or you can emulate external bus mode. Or you can emulate a mix of both modes. # 3. "Hooks"-Mode PODs The "hooks" type of POD Nohau offers uses a different technique for emulating. Certain chips can be put into a proprietary "hooks" mode that multiplexes the port information in and out of the part. The chip can still put out address and data. Most have 16 MHz versions available. This group includes these PODs: The POD-C752 is for emulating the 83C752 and 87C752. It has a 28 pin DIP plug on the bottom of the POD. You also can get an adapter to plug into 28 pin PLCC sockets. The POD-C52 can emulate the 80/80C/87/87C51, 80/80C/87/87C52, 80/80C31 and 80/80C32. You can use this POD when you need to emulate the 8052-type parts in single-chip mode when you are using Timer 2. The POD-L51P-16 can emulate the 8XL51FA/FB and can operate down to 3.0 volts. The POD-C528 can emulate the 80/80C/87/87C528 and 83/87C524. The POD-C592-PGA can emulate the 8XC592. See the previous discussion about PGAs. The POD-C550-PGA can emulate the 80/80C/87/87C550. It has a 44-pin PGA plug. You also can get an adapter to plug into 44-pin PLCC sockets. The POD-C558-16 can emulate the 83CE558 ad 89CE558. The POD-C575 can emulate the 8X575. The POD-C054 can emulate the 8XC053/054/055 "MTV" chip. With the "Hooks"-Mode PODs, you use jumpers to select whether the code is to be fetched from the emulator RAM or from external ROM. You also select whether the read-write memory is in the emulator or on your target board. The ports on these PODs may have slightly different electrical characteristics than the microcontroller. Specifically, some output signals can appear up to three clock cycles later than on the actual part. Also, some ports have greater current sink or sink and source capacity or slightly higher impedance than the actual part. For almost all applications, these differences will have no detrimental effects. You can use any size EMUL51-PC emulator and optional trace board with any POD you choose in Nohau's EMUL51-PC family. Choose an emulator and trace board with frequencies as fast or faster than the frequency of your fastest POD. If you need more information about which POD would best fit your application, please contact Nohau. #### Description The PDS51 is a board-level, full featured, 12 MHz In-Circuit Emulator for the Philips 8XC51 family of Microcontrollers. It allows the user complete access to the internal registers and full execution control with no chip resources being consumed. This means that the microcontroller in the target system can be replaced with the PDS51 enabling the target system to be easily run, monitored and debugged without any changes to code or hardware. The PDS51 is supplied with sufficient memory to enable emulation of the complete 64K of directly addressable code memory and a 28K line by 32 bit wide, realtime trace buffer. The PDS51 system consists of two interconnected modules. One board (the motherboard), contains the systems that are common to any derivative emulation such as the control microcontroller, logic, communication interface and power supply. The second board (the daughterboard), contains the bondout microcontroller which determines the target devices able to be emulated. Most daughterboards are able to emulate more than one derivative, thereby enhancing system flexibility with minimal expense. External breakpoint and trace control inputs, along with emulation running and fetch address controlled output trigger signals, are provided for interfacing and synchronising to external equipment. The PDS51 is controlled via an RS232 serial interface by a PC running terminal emulation or the PDS51-IDE debugger suppied. The Integrated Development Environment is a windowed command and display environment which runs on PC XT, AT, 386, 486 or compatibles. The PDS51 requires an external 6.5-9.5V 750mA DC power source. #### **FEATURES** - Supports Philips 80C51 family - Universal motherboard - Bondout dependent daughterboard - In-Circuit emulation - No stolen resources - 64K emulation code space - Hardware breakpoints (64K) on: Fetch address Fetch address and external signal - Real-time trace (28K frames) - Traced information: Fetch Address 12 External trace probes Control info (inta, c1) - Conditional trace on: Fetch address External signal - RS232 interface to PC - Controlled via the Integrated Debugger or Terminal Emulation using the SDS command set - Integrated Development Environment: Windowed interface Pull down menus Borland style keystrokes Symbolic or Source level debugging File formats supported: BSO/Tasking Kiel Franklin IAR Archemedies Metalink Intel Hex OMF51 On-line help: context sensitive hypertext style The PDS51 IDE (Integrated Development Environment) is a full screen, full featured debug and analysis interface to the PDS51 Development System. It provides an easy to use windowed environment that consists of 6 non-overlapping resizable panes that display Code, SFR Resources, Watch Variables, Internal Data RAM, External Data RAM (if enabled) and the Stack area. The IDE integrates the user's text Editor and Compiler/Assembler programs into the debug environment by providing fast and easy hot-key access. ``` Pile Settings Options Code : DEMO1.C 69 Contents main(){ Index main */ unsigned char i; Using Help an_integer = 4660; a_long = 1463898692; a_float = 7.6; for(i=0;i<24;++i){ /* test integer /* test long in /* test floatin Error Messages 8051 Reference About PDS51 */ /* fill string a_string[i] = i+65; if ((Speed == Setpoint) !! (Speed == AlarnVal))( strcpy(Status, error); Resources r0 (0) r7 (0) r4 (0) r6 (0) acc 3Fh psw 10000000b 55 52 OrOint 00 45 СУ Ŋ. 11001101b External Data Й 1 9996 DD 99 85 67 57 98 46 90 | àgWÿF Watches = an_integer (INT BYTE) : 18 a_long (INT QUAD) : 1463898692 a_string (INT ASCIIZ) : 'ABCDEFGHIJKLMMOPQRSIUUWXOK' a_float (INT FLOAT) : 7.6E+00 ``` The enhanced PDS51 IDE now facilitates source-level debugging for a variety of high level language compilers for the 80C51 including BSO/Tasking, Franklin/Keil and IAR/Archemedes 'C' complilers, as well as assemblers like Metalink. Borland compatible hot-keys provide fast and familiar access to frequently used functions, while pull down menus lead the new user to the desired operation. A comprehensive on-line help facility provides indexed, context sensitive, and hypertext style help on PDS51 IDE operation, as well as 80C51 architecture and instruction set. The code pane can be selected to display either a disassembly of the currently loaded program, or the source code itself. These modes are termed assemblylevel and source-level respectively, and are readily switched between. A cursor is used to direct the debug operations with execution proceeding either at full speed or single stepped. Displayed variables are updated to accurately reflect the status of the emulator. When programming using a compiler, your source code (C, Pascal etc.) will appear in the code pane in source-level mode, and debugging can be done directly in terms of the high-level language statements. switching to assembly-level mode, you will see the assemblylanguage code which the compiler generated. When has programming using assembler, your source code (including all comments etc.) will appear in the code pane in sourcelevel mode and by switching to assembly-level mode, you will see only the assembly-language code. Breakpoints, triggers, trace inhibits and external breakpoints may be hot-key set and cleared at the cursor and are visible to the user as background shading of the corresponding lines of code. These settings may be specified /\* begging of main \*/ main(){ unsigned char i; a float = an\_inte a\_long a\_float Internal RAM at 54h Address Original Value for(i=0 010000001111<u>00110011001100110</u>011b Binary Hex if ((Sp Signed Unsigned str '0' #243' 33' Character res Ploat String Resources Display Length Display Order QUAD/FLOAT acc high-byte first 1000 psw GrØint UVVX Enter new value : 7.5999999E+80 СУ Watches : nn\_integer (INT\_BYTE) : 18 a\_long (INT\_QUAD) : 1463898692 a\_string (INT\_ASCLIZ) : 'ABCDEFCHIJKLMNOPQRSTUUUXOK' 11mat (INT FLOAT) : 7.6E+08 in partitions and / or selected from a symbolic picklist. The resource pane provides access to the special function register resources of the emulated derivative, while the watch pane provides access to user defined variables contained in the internal/external RAM. The layout, content and display format of these panes are user definable and may be edited at any time. Valid entry and display formats are hexadecimal, ascii, binary, signed and unsigned decimal, as well as IEEE floating point, Pascal string and 'C' string. Data may also be entered directly into internal and external memory and stack areas. The huge 28K x 32 bit trace buffer is loaded in real time to provide subsequent viewing of past events. Executed Options TRACE.LST 14 Trace Buffer TRI status TRA 01000000 0010 r fetch 01000000 0010fetch MOV 0010 00100000 inc fetch 0010 fetch main sjmp 0010 09100000 dunny 0010 a p2, 00100000 0010 fetch 0059 mov 0010 fetch BASB 00010000 0011 005D sjmp fetch 00010000 00010000 0011 9911 fatch a, p2 0011 fetch $\mathbf{r}\mathbf{r}$ fetch 00010000 0011 0059 mov 0011 00001000 p3 fetch 005B inc 0011 0011 fetch 00001000 005D main sjmp 00001000 dunny 00001000 0011 fetch 8056 mov a, p2 000<u>01</u>000 0011 0058 fetch delta = +6 cycles (+6.000 us) Сy 28 00 00 00 00 00 00 00 00 00 30 00 00 00 00 00 00 00 00 p2.4 Edptr smod #255 07204 0000h code is presented in symbolic format on a cycle by cycle basis along with 12 user configurable sampled inputs. Trace buffer viewing is aided by a cursor and a moveable reference bar between which code execution times are calculated. An Execution Profiler is provided for identifying hot-spots or dead code for subsequent code optimization. This is in the form of a histogram of program fetches vs address bins. The address bin size and scale are adjustable. Support for enhanced video display modes is provided for VGA and EGA displays to allow for more information on screen. #### **SPECIFICATIONS** ■ Emulation: 64K bytes of code space In-circuit emulation via bondout No stolen resources Real time Universal motherboard Bondout dependant daughterboard (each emulating several derivatives) Trace Memory: 28K bytes deep, 32 bits wide 16 bit program address 12 bits of port lines or user signals External probes sampled S5P1 Control info (C1, INTA) Trace input filtering on the fetch address ■ Breakpoints: Hardware implimented Up to 64K on program fetch addresses Up to 64K on external signal input AND specified program fetch address ■ User Interfaces: 1) Windowed full screen debug environment Requires: PC/XT/AT/386/486 or compatible MSDOS ver 3.10 or later 512K bytes of available RAM Monochrome/EGA/VGA 2) Dumb Terminal Emulation using SDS command line instructions ■ Integrated Development Environment: File Formats Supported with Symbolic or Source-Level Debugging: BSO/Tasking, Franklin/Keil, IAR/Archemedes, Metalink, Intel Hex, OMF51, and more. Windowed environment with 6 non-overlapping resizable panes: HLL source or symbolic disassembly code SFR resources Internal/external RAM Stack area User watch variables Pull-down menus Enhanced video display modes available (28/50 line VGA, 43 line EGA) Keyboard control, intuitive keystrokes and Borland compatible hotkeys Fast hotkey access to user Editor/Assembler/Compiler applications Data entry and display formats (examine/modify): Hexadecimal, Ascii, Binary, Signed and unsigned decimal IEEE floating point, Pascal string or 'C' string Emulation Controls: Reset bondout Run from current program counter Run from current program counter to cursor Modify program counter Single step (source-level line or assembly instruction) Step over calls Step into next call or procedure Reposition cursor at address (or label selected from picklist) Follow program without executing Trace Display: Window into 28K lines of trace buffer Fetch addresses Symbolic code format Status (fetch, dummy, inta etc.) 12 external probes (boolean format) Adjustable references for execution time calculation 64K of trace ON/OFF settings (trace filter) Execution Profiler: Bar graph: No. of Fetches vs Address bins Adjustable bin sizes and scaling Breakpoints, external breakpoints, triggers, trace filters all setable via specified address range, symbol picklist, or keybinding over 64K code space. On-line Help: Context sensitive Indexed, Hypertext style 8051 architecture/instruction set ■ Interface Signals: Force Trace I/P pin Overides trace input filter External Breakpoint I/P pin Breaks on an external event. Fetch address sensitive over 64K range (sampled S2P1) Emulation Active O/P pin Signals when program running External Trigger O/P pin Trigger O/P for synchronising external test equipment. Fetch address controlled over 64K range (updated S2P1) Speed: 3.5 to 12 MHz no wait states no stolen cycles Serial Interface: RS232C Asynchronous, 8 data, no parity, 1 stop bit 9 Pin 'D' connector Rxd/Txd jumper swapable 9.6K/19.2K/38.4K/115.2K Baud (jumper selectable) Xon/Xoff handshaking Motherboard with daughterboard 130mm x 110mm x 42mm (L.W.H) ■ Power Supply: 9V nominal (6.5-9.5V) 800mA max, 500mA typical 3.5mm Phono plug centre +ve | DEVICE | DAUGHTERBOARDS<br>ABLE TO EMULATE | PACKAGE EMULATION | | |---------|-----------------------------------|-------------------|-------------| | | | SUPPLIED | OPTIONAL | | 8xC053 | PDB054 | SDIP42 | | | 8xC054 | PDB054 | SDIP42 | | | 8xC055 | PDB054 | SDIP42 | | | 8xC51 | PDB51FB, PDB52,<br>PDB654, PDB552 | DIP40 | PLCC44 | | 8xC51FA | PDB51FB | DIP40 | PLCC44 | | 8xC51FB | PDB51FB | DIP40 | PLCC44 | | 8xC51FC | PDB51FC* | DIP40 | PLCC44 | | 8xC52 | PDB52, PDB51FB | DIP40 | PLCC44 | | 8xC54 | • | DIP40 | PLCC44 | | 8xC58 | * | DIP40 | PLCC44 | | 8xC504 | PDB504* | DIP40 | PLCC44 | | 8xC524 | PDB528* | DIP40 | PLCC44 | | 8xC528 | PDB528* | DIP40 | PLCC44 | | 8xC550 | PDB550* | DIP40 | PLCC44 | | 8xC552 | PDB552 | PLCC68 | To have the | | 8xC562 | PDB552 | PLCC68 | 100 | | 8xC592 | PDB592* | PLCC68 | • | | 8xC652 | PDB654, PDB552 | DIP40 | PLCC44 | | 8xC654 | PDB654, PDB552 | DIP40 | PLCC44 | | 8xC748 | PDB752 | SDIP24 | PLCC28 | | 8xC749 | PDB752 | DIP28 | PLCC28 | | 8xC750 | PDB752 | SDIP24 | PLCC28 | | 8xC751 | PDB752 | SDIP24 | PLCC28 | | 8xC752 | PDB752 | DIP28 | PLCC28 | <sup>\*</sup> DAUGHTER BOARD IN DEVELOPMENT, PLEASE ENQUIRE #### Ordering Information: Please quote the following codes when ordering: | PDS51 | Motherboard | 9351 719 40112 | |----------------|------------------------|----------------| | PDB752 | Daughterboard | 9351 720 00112 | | PDB654 | Daughterboard | 9351 719 80112 | | PDB552 | Daughterboard | 9351 719 70112 | | PDB52 | Daughterboard | 9351 719 60112 | | PDB51FB | Daughterboard | 9351 719 50112 | | (not all codes | available at time of n | | #### Description The P8051LCP40 SD and P8051LCPX SD are low cost, board level products which together program most of Philips 87C51 microcontroller derivatives. The programmers connect to the serial port of a PC or compatible and are controlled by the interface software supplied. The programmers will read, blank check, program and verify code bytes, security bits and the encryption array. Both EPROM and EEPROM programming algorithms are supported. The P8051LCP40 SD has ZIF sockets which accomodate 40-Pin DIP and 44-Pin PLCC 87C51 derivatives while the P8051LCPX SD has ZIF sockets which accomodate 24- and 28-Pin DIP, and 68-Pin PLCC 87C51 derivatives. Adapters are available which extend the range of devices and package types able to be programmed by each programmer. Up to 8 programmers may be serially connected together ("ganged") for the similtaneous programming of multiple devices. An external 9V DC power source is required (200mA per board). #### Features - Program code space - Read code space - Verify - Blank Check - Program security fuses - Program encryption array - PC software user interface - Diskfile I/O (Intel Hex) - Cascadable for "gang" programming - Zero insertion force sockets - Adapters extend the range of programmable devices - Upgradable The P8051LCPX and P8051LCP40 programmers are supplied with a full screen PC interface. The intuitive display shows an outline of the programmer hardware indicating what sockets and devices to use and accurately reflecting the programmers current status. The function keys allow fast and easy control of the basic operations: Blank Check Check ROM locations are all FFh Program Writes code from buffer into device Verify Ensures a match between buffer code and micro controller code Security Program and verify security bits The Auto function performs all of the above operations sequentially to minimise operator intervention. Only a single PC interface is required to coordinate the operations of up to 8 'gang-connected' programmers for programming multiple devices simultaneously. The Read ROM function allows the master ROM contents to be read from the target microcontroller into the PC code buffer which may then be inspected (hex format), saved to disk (Intel hex file), or reprogrammed into other devices. Hex files may also be read from disk to the buffer for subsequent programming, viewing or encryption. The programmer interface is fully equiped for programming and verifying encryption arrays and encrypted code. Data read or verified is automatically deencrypted. Buffer Contains: OMS027.HEX The new operator is assisted by the on-line context-sensitive help facility. The interface is continuously upgraded in support of new devices as they become available. Upgrade kits are available from your nearest Philips dealer. 892 Full CheckSum : \$E57C The software requires a host IBM PC/XT/AT/386/486 personal computer with an RS-232 serial port. # **Each Programmer Kit Includes:** (both kits include the necessary hardware and software to program Philips microcontrollers using an IBM compatible PC/XT/AT/386/486) - Programmer board with zero insertion force I.C sockets, 9 pin serial D connector (RS232), 9V power connector - Control software on 3½" floppy disk - User manual - Phono power plug and cable for connection to external power supply (plus in U.S.A only: RS-232 cable, 9-25 pin D connector adaptor, 110V AC to 9V DC adaptor) ### Adaptors: A range of adaptors is available which extends the list of devices and package types able to be programmed. Most adaptors are two-piece adaptors which consist of a Package Adaptor fitted to a specific Device Adaptor, which in turn is inserted into the 40 pin DIL ZIF socket on the P8051LCP40 SD. They are designed so one package adaptor may be shared between several device adaptors, thus minimising costs. See the selection table opposite. #### **Ordering Information:** Please quote the following codes when ordering from your nearest Philips distributor. | P8051LCP40 SD | 9350 282 90112 | |---------------|----------------| | P8051LCPX SD | 9350 278 80112 | | LCP40-QFP44 | 9350 451 30112 | | LCP40-P80QFP | 9350 750 40112 | | LCP40-P68LCC | 9350 750 50112 | | LCP40-D552 | 9350 750 60112 | | LCP40-D558 | 9350 750 70112 | | LCP40-D592 | 9350 750 80112 | | LCP40-D598 | 9350 750 90112 | Note: If the order code for the desired part is not listed, please enquire at your nearest Philips distributor. | LC | PPROG | HAMINER SEL | ECTION GUIDE | |----------|---------|---------------|----------------------------------------| | DEVICE | PACKAGE | PROGRAMMER | ADAPTOR | | 28-11 E. | DIL40 | P8051LCP40 SD | | | 87C51 | PLCC44 | P8051LCP40 SD | | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | 87C51FA | DIL40 | P8051LCP40 SD | | | | PLCC44 | P8051LCP40 SD | ************************************** | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | 87C51FB | DIL40 | P8051LCP40 SD | | | | PLCC44 | P8051LCP40 SD | | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | | DIL40 | P8051LCP40 SD | 4. | | 87L51FB | PLCC44 | P8051LCP40 SD | | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | | DIL40 | P8051LCP40 SD | | | 87C52 | PLCC44 | P8051LCP40 SD | | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | 87C054 | SDIL42 | P8051LCPX SD | LCPX-054SDIL | | 87C055 | SDIL42 | P8051LCPX SD | LCPX-054SDIL | | 87C451 | PLCC68 | P8051LCPX SD | | | 0.0.0. | DII 40 | P8051LCP40 SD | • | | 87C524 | PLCC44 | P8051LCP40 SD | - N. | | a, oget | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | | DIL40 | P8051LCP40 SD | | | 87C528 | PLCC44 | P8051LCP40 SD | | | 870326 | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | | DIL40 | P8051LCP40 SD | 201 10 411 11 | | 87C550 | PLCC44 | P8051LCP40 SD | | | | FLCC44 | P8051LCPX SD | | | 870550 | PLCC68 | P8051LCP40 SD | LCP40-D552 & LCP40-P68LCC | | 87C552 | OFFRO | P8051LCP40 SD | LCP40-D552 & LCP40-P80QFP | | | QFP80 | P8051LCP40 SD | ECF40-D332 & ECF40-FBCGIT | | | | | | | 87C575 | PLCC44 | P8051LCP40 SD | LCP40-QFP44 | | | QFP44 | P8051LCP40 SD | | | 87C592 | PLCC68 | P8051LCP40 SD | LCP40-D592 & LCP40-P68LCC | | 87C598 | QFP80 | P8051LCP40 SD | LCP40-D598 & LCP40-P80QFP | | | DIL40 | P8051LCP40 SD | • | | 87C652 | PLCC44 | P8051LCP40 SD | | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | | DIL40 | P8051LCP40 SD | | | 87C654 | PLCC44 | P8051LCP40 SD | | | | QFP44 | P8051LCP40 SD | LCP40-QFP44 | | 87C748 | SDIL24 | P8051LCPX SD | and the states | | 0/0/40 | PLCC28 | P8051LCPX SD | LCPX-751PLCC | | 87C749 | DIL28 | P8051LCPX SD | | | 6,0,48 | PLCC28 | P8051LCPX SD | LCPX-752PLCC | | 87C750 | SDIL24 | P8051LCPX SD | • | | 8/0/50 | PLCC28 | P8051LCPX SD | LCPX-751PLCC | | 07075 | SDIL24 | P8051LCPX SD | | | 87C751 | PLCC28 | P8051LCPX SD | LCPX-751PLCC | | | DIL28 | P8051LCPX SD | • 1 | | 87C75 | PLCC28 | P8051LCPX SD | LCPX-752PLCC | | 89CE55 | 8 QFP80 | P8051LCP40 SD | LCP40-D558 & LCP40-P80QFI | | 89CE55 | | P8051LCP40 SD | LCP40-D558 & LCP40-P80QFI | <sup>\*</sup>Support for the 87C504, 87C51FC, 87C54, 87C58, 87C576, 87C134 and 24/28 pin SSOP devices is intended but not available at the time of printing. #### Description The S87C00KSD Evaluation Board is a low cost, board-level product designed for evaluation of the I<sup>2</sup>C bus and Philips 80C51 microcontrollers. Its modular board layout and modular software make it useful for fast prototyping and as an educational tool. This board is supplied with an 87C751 microcontroller pre-programmed with software which demonstrates I<sup>2</sup>C implimentation, and application of a number of I<sup>2</sup>C peripherals. Sockets for the 87C752, 87C654/528, and the 87C552 are included on the board to facilitate customer development of these microcontrollers. #### **Board Modules:** - Microcontroller (87C751) - LCD Display (PCF8577 / LTD226F-12) - LED Display (SAA1064) - 8-bit Parallel I/O (8574A) - 8-bit Parallel I/O (8574) - RAM (PCF8570) - EEPROM (PCF8582) - Clock/Calendar (PCF8583) - DTMF Dialer (PCF3312 / TDA7050T) - A/D and D/A (PCF8591) - Socket for 87C752 - Socket for 87C654/528 - Socket for 87C552 with external RAM and Latch - RS232 Interface - Prototyping Area # **Ordering Information:** Please quote the following code when ordering from any Philips distributor. S87C00KSD 9350 107 50112 For evaluation of the 82C200 CAN-bus controller hooked to a 8XC552 microcontroller, Philips Semiconductors offers the OM4130 board. It is a low-cost prototyping board for interactive development of programs for full access to the CAN bus. Major features of the OM4130 include: - Evaluation of the 82C200 CAN controller - Full support of the CAN communication utilities: - demonstration and monitor software for the CAN-bus system supports CAN communication of up to 1 Mbits/sec - interactive configuration of the CAN controller - CAN physical layer circuitry for balanced bus wires - LED display - Interactive software development with up/down-loading of user-specific hex files - On-board monitor software (EPROM) - RS232C interface for connection to a PC, a terminal such as a VT100 or a workstation with terminal emulation - Wire-wrap area for prototyping, an application interface and a two-wire CAN-bus connector - Supply voltage: 7.5 to 18 V - Dimensions: 100 × 200 mm. The OM4130 comes with serial interface and supply voltage connectors. OM4130 — CAN Evaluation Board with 8XC552 Microcontroller and 82C200 CAN Controller Ordering Code: OM4130 April 1994 835 # CAN evaluation board with the 8XC592 microcontroller OM4239 For evaluation of the 8XC592 microcontroller's CAN-bus interface, Philips Semiconductors offers the OM4239 board. It is a low-cost prototyping board providing powerful monitor functions for nteractive development of programs for full access to the CAN bus. Major features of the OM4239 include: - Evaluation of the 8XC592 microcontroller's CAN interface - Full support of the CAN communication utilities: - demonstration and monitor software for the CAN-bus system supports CAN communication of up to 1 Mbits/sec - interactive configuration of the CAN controller - CAN physical layer circuitry for balanced bus wires - detachable LED display - Interactive software development with up/down-loading of user-specific hex files - On-board monitor software (EPROM) - RS232C interface for connection to a PC, a terminal such as a VT100 or a workstation with terminal emulation - Wire-wrap area for prototyping, an application interface and a two-wire CAN-bus connector - Supply voltage: 7.5 to 18 V - Dimensions: 100 × 160 mm. The OM4239 comes with serial interface and supply voltage connectors. OM4239 — CAN Evaluation Board with the 8XC592 Microcontroller 836 Ordering Code: OM4239 April 1994 # **Evaluation board for the 8XCE598 microcontroller** For evaluation of the 8XCE598 microcontroller and its CAN-bus interface, Philips Semiconducotrs offers the OM4240 board. It is a low-cost prototyping board providing powerful monitor functions for interactive development of programs for full access to the CAN bus. Major features of the OM4240 include: - Evaluation of the 8XCE598 microcontroller and its CAN interface - Full support of the CAN communication utilities: - demonstration and monitor software for the CAN-bus system supports CAN communication of up to 1 Mbits/sec - interactive configuration of the CAN controller - a plug-in CAN physical layer baby board with the 82C250 CAN transceiver IC for balanced bus wires - LED display - Interactive software development with up/down-loading of user-specific hex files, single/multi-step breakpoint setting and software trace functions - On-board monitor software (EPROM) and a PC-DOS compatible cross-assembler on a diskette - On-board programming of a 87CE598 - RS232C interface for connection to a PC - Wire-wrap area for prototyping, an application interface and a two-wire CAN-bus connector - Supply voltage: 7.5 to 18 V - Dimensions: 200 × 160 mm. The OM4240 comes with serial interface cable an a supply voltage connector. OM4240 — Evaluation Board for the 8XCE598 Microcontroller Ordering Code: OM4240 # SLIO evaluation board with the 82C150 and 82C250 CAN ICs OM4272 For a cost-effective implementation of CAN nodes, Philips Semiconductors offers the OM4272 SLIO (Serial Linked I/O) board. The board includes a P82C150 single-chip I/O device with a CAN protocol controller and a PCA82C250 CAN transceiver which interfaces to a physical bus complying with the ISO/DIS 11898 standard Major features of the OM4272 include: - Low-cost interface between I/O and CAN bus - Meets CAN protocol specification version 2.0A and B (passive) with restricted bit timing - Sample software is provided for control/configuration of up to 16 OM4272 nodes via the CAN bus: - ready to use for exercising the P82C150 - runs on an OM4239 or OM4240 board - uses all types of SLIO messages - sends calibration messages, checks presence of SLIO devices and switches the on-board LED connected to a port pin of the P82C150 - source code written in C and down-loadable hex files are provided on a 3.5" diskette - Full automatic bit rate detection and calibration - 10-bit analog-to-digital conversion with up to six multiplexed analog input channels - Up to 2 quasi-analog outputs with 10-bit accuracy - On-board facilities for low-pass RC filters for analog-to-digital converter and quasi-analog outputs - The application interface connector is hooked to all I/O ports, reset, test, and power pins - Optional external clock mode via the application connector - Supply voltage: 7.5 to 18 V - Dimensions: 50 x 52 mm. The OM4240 comes with serial interface cable an a supply voltage connector. OM4272 — SLIO Evaluation Board with the 82C150 and 82C250 CAN ICs Ordering Code: OM4272 April 1994 838 # P83C852 Smart Card crypto-controller demonstration kit OM4280 For the fast growing market of smart cards, Philips Semiconductors offers the OM4280 demonstration kit for evaluationg its P83C852 Crypto Controller. This demo kit enables the user to evaluate the smart card operating system implemented on the P83C852. The operating system provides several functions including PIN verification, various memory functions and debiting. It also supports more complex functions required for, e.g., point-of-sale applications and encryption/decryption functions for confidential data transfer including a personal signature in, e.g., open FAX systems. The wide spread use of smart cards requires thorough information security. The oM4280 demo kit particularly addresses this issue. The P83C852 Crypto Controller has an on-chip accelerator for fast asymmetric enciphering using the RSA algorithm. A sample program on the OM4280 supports secret and public keys for two persons named Alice and Bob. The user can assign, however, any other pair of secret/private keys on the card. The demonstration kit is supplied with: - An operating manual - · A full description of the card operating system - Two Smart Cards each with a P83C852 CMOS crypto controller - A card reader - A PC interface cable - A mains adaptor - Diskettes with the Smart Card demo software and source code for an RS-232 interface to a PC's serial port OM4280, P83C852 Smart Card Crypto Controller Demonstration Kit Ordering Code: OM4280 Philips Semiconductors Product specification Evaluation board PEB552 The PEB552 is a low-cost, easily customized single extended euro-card for the Philips high performance PCB80C552 microcontroller. The PEB552 can be programmed in high-level PLM51, Forth, Basic, C languages or conventional assemblers. A major design feature of the PEB552 is its large, $11 \times 38$ , wire-wrap prototyping area in a 0.1-inch grid. All the microprocessor signals, I/O decoding and an uncommitted 96-pin connector are conveniently routed to the edge of the prototyping area. The fully expanded memory offers 124 kbytes of RAM and EPROM and 4 kbytes of reconfigurable decoded I/O space. The PEB552 has been designed for on-board EPROM programming. These programs can be executed at power-up or reset. The high programming voltages required for the EPROMs are provided by a piggy-back module which readily plugs into the PEB552. To operate the PEB552, simply connect it to your PC and run a suitable terminal emulator program. The turn on the board's 5 V power supply and the PEB552 will respond with a message indicating that it is ready to use. #### **PEB552 FEATURES** - CMOS PCB80C552 processor based on the industry standard 80C51 - Wire-wrap prototyping area with uncommitted 96-pin DIN41612 connector - All processor pins available on pin-headers near the prototyping area - Full duplex RS232 interface to 25-pin or 9-pin D-shell connectors - Two-wire I<sup>2</sup>C serial communication bus - 32 kbytes of RAM expandable to 64 kbytes - Optional battery back-up - 256 bytes of RAM on the PCB80C552 - 32 kbytes of EPROM including a powerful monitor program. Expandable to 64 kbytes. - Optional on-board EPROM programming capability for up to 32 kbytes of EPROM - Optional on-board 87C552 microcontroller programming - Reconfigurable memory-mapped I/O decoding - Eight analog inputs multiplexed to a 10-bit ADC - Two PWM outputs can be used as 8-bit DACs - Five 8-bit I/O ports - One 8-bit input port shared with the analog inputs - Two 16-bit timer/counters - One 16-bit timer counter coupled to four capture registers and three compare registers - Two watchdog timers - Fifteen interrupt vectors - Single 5 V supply - Power-on reset - Power-fail detect and automatic battery back-up switch over. PEB552 Evaluation Board Philips Semiconductors Product specification ### Evaluation board PEB552 #### HARDWARE SPECIFICATIONS #### **Processor and Memory** The heart of the PEB552 is the Philips PCB80C552 microcontroller operating at 11.059 MHz. The board is supplied with 32 kbytes of static RAM and 32 kbytes of EPROM. The memory can be further expanded to 64 kbytes of RAM and 64 kbytes of EPROM. Two RAM sockets enable the use of either 8 or 32 kbyte devices and two EPROM sockets enable the use of 8, 16 or 32 kbyte devices. The second of the two EPROM sockets is available for EPROM programming. The memory and I/O maps are completely configurable by either jumper selections or, for customized requirements, via an industry standard programmable logic device. #### Serial I/O A full-duplex RS232 interface is implemented on the PEB552. The RS232 connector on the board enables a flat cable to be made up for the 25-pin or 9-pin D-shell connector conventions required by the IBM PC/XT and /AT computers and compatibles. Jumpers are provided to select the conventions for the transmit, receive and ground signals. The 11.059 MHz crystal frequency on the PEB552 can be used in conjunction with an on-chip timer to generate baud rates up to 19200 baud. An I<sup>2</sup>C-bus controller for two-wire serial communication with I<sup>2</sup>C-bus compatible ICs is also provided. the I<sup>2</sup>C serial I/O has complete autonomy in byte handling and operates in 4 modes: - Master transmitter - Master receiver - Slave transmitter - Slave receiver #### Parallel I/O All of the processor signals are routed to pin headers at the edge of the prototyping area. The PCB80C552 processor offers five 8-bit I/O ports and one 8-bit input port. When using the processor in expanded mode, a dedicated 4 kbyte memory-mapped I/O space is enabled. The memory-mapped I/O is further decoded to produce 8 I/O select signals available on a pin header close to the prototyping area. #### **Watchdog Timers** Watchdog timers are an important feature of embedded microcontroller applications. The purpose of a watchdog timer is to reset the microcontroller if it enters an erroneous state within a reasonable period of time. The PEB552 has two watchdog timers: one is external to the PCB80C552 and has a time-out period of 1.4 s, and the other is part of the processor and has a programmable time-out period between 2 ms and 500 ms. Both watchdog timers are enabled with jumpers on the PEB552. If either watchdog times out, a reset pulse is generated. #### **External Connections** An uncommitted DIN41612 connector is available at the edge of the card and positioned in front of the prototyping area. Its 96 connections are routed to holes on the prototyping matrix. All of the PCB80C552 processor pins with the exception of the crystal pins are available on the pin headers. #### **EPROM and 87C662 Processor Programming** For easy on-board EPROM programming, sufficient board area is available on the PEB552 for a 28-pin ZIF socket to hold an 8, 16, or 32 kbyte EPROM. Source code developed using high-level languages or assemblers can be burnt into the EPROM by using the optional PEB552VA voltage converter adapter and a pre-programmed 87C552 microcontroller. The PEB552VA plugs into a connector on the PEB552 and converts the 5 V supply voltage to 5, 6, and 12.5 V required for EPROM programming. The adapter is controlled by a signal from the controller. A 87C552 can be programmed using an optional 87C552 programming adapter. #### **Battery Back-up** An external 2 to 4 V battery can be used to retain data in RAM. A precision voltage level detector automatically switches the 5 V supply over to the battery supply when the 5 V supply drops 50 mV below the battery level. Battery supply is switched to the main supply when the main voltage rises 50 mv above the battery level. The precision voltage level detector also provides a power-fail signal that is available as an interrupt signal to the processor. #### SOFTWARE SUPPORT The PEB552 is supplied with a monitor program — MON552 — consisting of a diskette and a 27C256 EPROM. The diskette is IBM PC-compatible and contains the host module for the monitor program. The EPROM code executes on the PEB552 and uses approximately 2 kbytes of the supplied 32 kbytes EPROM. Existing systems can be upgraded with a pre-programmed 87C552 to replace the EPROM monitor and to provide both EPROM and 87C552 programming capability with the aid of the appropriate adapters. The monitor module provides the minimum functionality required to: - Read and write to internal and external RAM - Read from program memory - Read and write to the special function registers - Load and save Intel hex files - Program execution control such as jump to a start address - Disassemble program memory - Single step through a program in RAM or EPROM - Set multiple break points The purpose of the host module is to provide a user interface for the monitor module. The host module communicates with the PEB552 via the serial RS232 interface. Commands and parameters are transmitted to the PEB552. The monitor module then interprets these commands and transmits the required data back to the host. The host software provides a window environment, a lexical analyzer and command interpreter. Higher level languages including PLM51, Forth, Basic, C and assemblers are readily available from various sources to develop executable code for the PEB552. #### **USER SUPPORT** Users must register the serial number of their PEB552 with Micro Amps Ltd., the designer and manufacturer of the board, to receive support. This registration entitles the user to receive telephone support, information regarding new software releases, details regarding associated software tools, operating systems and customization facilities. #### **ORDERING INFORMATION** The ordering code for the complete PEB552 package: 9339 953 0112 This package includes: - PEB552 evaluation board - PEB552 hardware manual - MON552 monitor manual - PCB80C552 user manual - REG552 registration form. #### Optionally available: - PEB552VA voltage adapter and 87C552 microcontroller for on-board EPROM programming - Adapter for on-board 87C552 microcontroller programming # Data handbook system # Appendix A ### **DATA HANDBOOK SYSTEM** Philips Semiconductors data handbooks contain all pertinent data available at the time of publication and each is revised and reissued regularly. Loose data sheets are sent to subscribers to keep them up-to-date on additions or alterations made during the lifetime of a data handbook. Catalogs are available for selected product ranges (some catalogs are also on floppy discs). Our data handbook titles are listed here. #### **Integrated Circuits** | Book | Title | |------|-----------------------------------------------------------| | IC01 | Semiconductors for Radio and Audio Systems | | IC02 | Semiconductors for Television and Video Systems | | IC03 | Semiconductors for Telecom Systems | | IC04 | CMOS HE4000B Logic Family | | IC06 | High-speed CMOS Logic Family | | IC11 | General-purpose/Linear ICs | | IC12 | I <sup>2</sup> C Peripherals | | IC13 | Programmable Logic Devices (PLD) | | IC14 | 8048-based 8-bit Microcontrollers | | IC15 | FAST TTL Logic Series | | IC16 | CMOS Integrated Circuits for Clocks and Watches | | IC17 | RF/Wireless Communications | | IC18 | Semiconductors for In-car Electronics | | IC19 | ICs for Datacommunications | | IC20 | 80C51-based 8-bit Microcontrollers | | IC22 | Desktop Video | | IC23 | QUBiC Advanced BiCMOS Bus Interface Logic ABT, MULTIBYTE™ | | IC24 | Low Voltage CMOS & BiCMOS Logic | | | | ### **Discrete Semiconductors** Title Book | DOOK | Tille | |----------|-------------------------------------------------------------| | SC01 | Diodes | | SC02 | Power Diodes | | SC03 | Thyristors and Triacs | | SC04 | Small-signal Transistors | | SC05 | Low-frequency Power Transistors and Hybrid IC Power Modules | | SC06 | High-voltage and Switching NPN Power Transistors | | SC07 | Small-signal Field-effect Transistors | | SC08a | RF Power Bipolar Transistors | | SC08b | RF Power MOS Transistors | | SC09 | RF Power Modules | | SC10 | Surface Mounted Semiconductors | | SC13 | Power MOS Transistors including TOPFETs and IGBTs | | SC14 | RF Wideband Transistors,<br>Video Transistors and Modules | | SC15 | Microwave Transistors | | SC16 | Wideband Hybrid IC Modules | | SC17 | Semiconductor Sensors | | Professi | onal Components | | PC01 | High-power Klystrons and Accessories | | PC01 | High-power Klystrons and Accessories | |------|--------------------------------------| | PC06 | Circulators and Isolators | #### MORE INFORMATION FROM PHILIPS SEMICONDUCTORS? For more information about Philips Semiconductors data handbooks, catalogs and subscriptions, contact your nearest Philips Semiconductors national organization, select from the address list on the back cover of this handbook. Product specialists are at your service and inquiries are answered promptly. # Data handbook system # OVERVIEW OF PHILIPS COMPONENTS DATA HANDBOOKS Our sister product division, Philips Components, also has a comprehensive data handbook system to support their products. Their data handbook titles are listed here. #### **Display Components** Book Title DC01 Colour TV Picture Tubes and Assemblies Colour Monitor Tubes DC02 Monochrome Monitor Tubes and Deflection Units DC03 Television Tuners, Coaxial Aerial Input Assemblies DC05 Flyback Transformers, Mains Transformers and General-purpose FXC Assemblies #### **Magnetic Products** MA01 Soft Ferrites MA03 Piezoelectric Ceramics Specialty Ferrites MA04 Dry-reed Switches #### **Passive Components** PA01 Electrolytic Capacitors PA02 Varistors, Thermistors and Sensors PA03 Potentiometers PA04 Variable Capacitors PA05 Film Capacitors PA06 Ceramic Capacitors PA07 Quartz Crystals for Special and Ind PA07 Quartz Crystals for Special and Industrial Applications PA08 Fixed Resistors PA11 PC12 PA10 Quartz Crystals for Automotive and Standard Applications Quartz Oscillators #### **Professional Components** PC04 Photo Multipliers PC05 Plumbicon Camera Tubes and Accessories PC07 Vidicon and Newvicon Camera Tubes and Deflection Units PC08 Image Intensifiers **Electron Multipliers** # MORE INFORMATION FROM PHILIPS COMPONENTS? For more information contact your nearest Philips Components national organization shown in the following list. Argentina: BUENOS AIRES, Tel. (541)786 7635, Fax . (541)786 9367. Australia: NORTH RYDE, Tel. (02)805 4455, Fax. (02)805 4466. Austria: WIEN, Tel. (01)60101 1820, Fax. (01)60101 1210. Belgium: EINDHOVEN, The Netherlands, Tel. (31)40 783749, Fax. (31)40 788399. Brazil: SÃO PAULO, Tel. (011)821 2333, Fax (011)829 1849. Canada: SCARBOROUGH, Tel. (0416)292 5161, Fax. (0416)754 6248. Chile: SANTIAGO, Tel. (02)77 38 16, Fax. (02)735 3594. China (Peoples Republic of): SHANGHAI, Tel. (021)326 4140, Fax. (021)320 2160. Columbia: BOGOTA, Tel. (571)249 7624/(571)217 4609, Fax (571)217 4549. Denmark: COPENHAGEN, Tel. (032)883 333, Fax. (031)571 949. Finland: ESPOO, Tel. (9)0-50261, Fax. (9)0-520971. France: SURESNES, Tel. (01)4099 6161, Fax, (01)4099 6431. Germany: HAMBURG, Tel. (040)3296-0, Fax. (040)3296 213. Greece: TAVROS, Tel. (01)489 4339/(01)489 4911, Fax. (01)481 5180. Hong Kong: KWAI CHUNG, Tel. (852)424 5121, Fax. (852)428 6729. India: BOMBAY, Tel. (022)4938 541, Fax. (022)4938 722. Indonesia: JAKARTA, Tel. (021)5201122, Fax. (021)5205189. Ireland: DUBLIN, Tel. (01)640 203, Fax. (01)640 210. Israel: TEL AVIV, Tel (9723)6450333, Fax. (9723)493272. Italy: MILANO, Tel. (02)6752.3302, Fax. (02)6752.3300. Japan: TOKIO, Tel. (03)3740 5143, Fax. (03)3740 5035. Korea (Republic of): SEOUL, Tel. (02)709-1412, Fax. (02)709-1415. Malaysia: KUALA LUMPUR, Tel. (03)757 5511, Fax. (03)757 4880. Mexico: CHI HUA HUA, Tel. (016)18-67-01/(016)18-67-02, Fax. (016)778 0551. Netherlands: EINDHOVEN, Tel. (040)783749, Fax. (040)788399. New Zealand: AUKLAND, Tel. (09)849-4160, Fax. (09)849-7811. Norway: OSLO, Tel. (22)74 8000, Fax (22)74 8341. Pakistan: KARACHI, Tel. (021)587 4641-49, Fax. (021)577035/5874546. Philippines: MANILA, Tel. (02)810-0161, Fax. (02)817-3474. Portugal: LINDA-A-VELHA, Tel. (01)14163160/4163333, Fax. (01)14163174/4163366. Singapore: SINGAPORE, Tel. (65)350 2000, Fax. (65)355 1758. South Africa: JOHANNESBURG, Tel. (011)470-5911, Fax. (011)470-5494. Spain: BARCELONA, Tel. (03)301 6312, Fax. (03)301 4243. **Sweden:** STOCKHOLM, Tel. (08)632 2000, Fax. (08)632 2745. **Switzerland:** ZÜRICH, Tel. (01)488 2211, Fax. (01) 481 7730. Taiwan: TAIPEI, Tel. (02)388 7666, Fax. (02)382 4382. Thailand: BANGKOK, Tel. (662)398-0141, Fax. (662)398-3319. Turkey: ISTANBUL, Tel. (0212)279 2770, Fax. (0212)269 3094. United Kingdom: LONDON, Tel. (071)590 6633, Fax. (071)636 0394. United States: RIVIERA BEACH, Tel. (407)881-3200, Fax, (407)881-3300. Uruguay: MONTEVIDEO, Tel. (02)704 044, Fax (02)920 601. For all other countries apply to: Philips Components. Marketing Communications, P.O. Box 218, 5600 MD, EINDHOVEN, The Netherlands Telex 35000 phtcnl, Fax. +31-40-724547. # North American Sales Offices, Representatives and Distributors #### **PHILIPS SEMICONDUCTORS** 811 East Argues Avenue P.O. Box 3409 Sunnyvale, CA 94088-3409 #### ALABAMA Huntsville Philips Semiconductors Phone: (205) 464-0111 (205) 464-9101 Elcom, Inc. Phone: (205) 830-4001 #### ARIZONA Scottsdale Thom Luke Sales, Inc. Phone: (602) 451-5400 Philips Semiconductors Phone: (602) 820-2225 ## **CALIFORNIA** Calabasas Philips Semiconductors Phone: (818) 880-6304 Philips Semiconductors Phone: (714) 453-0770 B.A.E. Sales, Inc. Phone: (916) 652-6777 San Diego Philips Semiconductors Phone: (619) 560-0242 San Jose B.A.E. Sales, Inc. Phone: (408) 452-8133 Sunnyvale Philips Semiconductors Phone: (408) 991-3737 # COLORADO Englewood Philips Semiconductors Phone: (303) 792-9011 Thom Luke Sales, Inc. Phone: (303) 649-9717 #### CONNECTICUT Wallingford JEBCO Phone: (203) 265-1318 #### **FLORIDA** Clearwater Conley and Assoc., Inc. Phone: (813) 572-8895 Conley and Assoc., Inc. Phone: (407) 365-3283 #### **GEORGIA** Norcross Elcom, Inc. Phone: (404) 447-8200 #### **ILLINOIS** Itasca Philips Semiconductors Phone: (708) 250-0050 Schaumburg Micro-Tex, Inc. Phone: (708) 885-8200 INDIANA Indianapolis Mohrfield Marketing, Inc. Phone: (317) 546-6969 #### Kokomo Philips Semiconductors Phone: (317) 459-5355 #### MARYLAND Columbia Third Wave Solutions, Inc. Phone: (410) 290-5990 #### MASSACHUSETTS Chelmsford JEBCO Phone: (508) 256-5800 Westford Philips Semiconductors Phone: (508) 692-6211 #### **MICHIGAN** Monroe S-J Associates Phone: (313) 242-0450 Philips Semiconductors Phone: (810) 347-1700 #### **MINNESOTA** Bloomington High Technology Sales Phone: (612) 844-9933 # **MISSOURI** Bridgeton Centech, Inc. Phone: (314) 291-4230 Raytown Centech, Inc. Phone: (816) 358-8100 #### **NEW JERSEY** Toms River Philips Semiconductors Phone: (908) 505-1200 (908) 240-1479 #### **NEW YORK** Ithaca Bob Dean, Inc. Phone: (607) 257-1111 #### **Rockville Centre** S-J Associates Phone: (516) 536-4242 Wappingers Falls Philips Semiconductors Phone: (914) 297-4074 Bob Dean, Inc. Phone: (914) 297-6406 #### **NORTH CAROLINA** Charlotte Elcom, Inc. Phone: (704) 543-1229 #### Greensboro Elcom, Inc Phone: (919) 273-8887 #### Matthews Elcom, Inc Phone: (704) 847-4323 OHIO Columbus S-J Associates, Inc Phone: (614) 885-6700 Kettering S-J Associates, Inc. Phone: (513) 298-7322 S-J Associates, Inc. Phone: (216) 349-2700 S-J Associates, Inc. Phone: (419) 727-8051 #### OREGON Beaverton Philips Semiconductors Phone: (503) 627-0110 Western Technical Sales Phone: (503) 644-8860 #### **PENNSYLVANIA** Erie S-J Associates, Inc. Phone: (216) 888-7004 Hatboro Delta Technical Sales, Inc. Phone: (215) 957-0600 Pittsburgh S-J Associates, Inc. Phone: (216) 349-2700 SOUTH CAROLINA Greenville Elcom, Inc. Phone: (803) 370-9119 #### **TENNESSEE** Dandridge Philips Semiconductors Phone: (615) 397-5053 ### **TEXAS** Austin Philips Semiconductors Phone: (512) 339-9945 Synergistic Sales, Inc. Phone: (512) 346-2122 Houston Synergistic Sales, Inc. Phone: (713) 937-1990 Richardson Philips Semiconductors Phone: (214) 644-1610 (214) 705-9555 Synergistic Sales, Inc. Phone: (214) 644-3500 # UTAH Salt Lake City Electrodyne Phone: (801) 264-8050 #### WASHINGTON Bellevue Western Technical Sales Phone: (206) 641-3900 Western Technical Sales Phone: (509) 922-7600 #### WISCONSIN Waukesha Micro-Tex. Inc. Phone: (414) 542-5352 CANADA **PHILIPS SEMICONDUCTORS** CANADA, LTD. Calgary, Alberta Philips Semiconductors/ Components, Inc. Phone: (403) 293-5969 Tech-Trek, Ltd. Phone: (403) 241-1719 Kanata, Ontario Philips Semiconductors Phone: (613) 599-8720 Tech-Trek, Ltd. Phone: (613) 599-8787 Montreal, Quebec Philips Semiconductors/ Components, Inc. Phone: (514) 424-7320 Mississauga, Ontario Tech-Trek, Ltd. Phone: (416) 238-0366 Richmond, B.C. Tech-Trék, Ltd Phone: (604) 276-8735 Scarborough, Ontario Philips Semiconductors/ Components, Ltd. (416) 292-5161 Ville St. Laurent, Quebec Tech-Trek, Ltd. Phone: (514) 337-7540 MEXICO **Anzures Section** Philips Components Phone: (800) 234-7381 El Paso, TX Philips Components Phone: (915) 775-4020 **PUERTO RICO** Caquas Mectron Group Phone: (809) 746-3522 # DISTRIBUTORS Contact one of our local distributors: Allied Electronics Anthem Electronics Arrow/Schweber Electronics Future Electronics (Canada only) Gerber Electronics Hamilton Hallmark Marshall Industries Newark Electronics Richardson Electronics Wyle Electronics Zeus Electronics 02/17/95 # Philips Semiconductors - a worldwide company Argentina: IEROD, Av. Juramento 1992 – 14.b (1428) BUENOS AIRES, Tel. (541) 786 7633, Fax. (541) 786 9367 Australia: 34 Waterloo Road, NORTH RYDE, NSW 2113, Tel. (02) 805 4455, Fax. (02) 805 4466 Austria: Triester Str. 64, A-1101 WIEN, P.O. Box 213, Tel. (01) 60 101-1236, Fax. (01) 60 101-1211 **Belgium:** Postbus 90050, 5600 PB EINDHOVEN, The Netherlands, Tel. (31)40 783 749, Fax. (31)40 788 399 Brazil: Rua do Rocio 220 – 5th Floor, Suite 51 CEP: 04552-903 SÃO PAULO-SP, Brazil P.O. Box 7383 (01064-970), Tel. (011) 821-2333, Fax (011) 829-1849 Canada: PHILIPS SEMICONDUCTORS/COMPONENTS: Tel. (800) 234-7381, Fax. (708) 296-8556 Chile: Av. Santa Maria 0760, SANTIAGO, Tel. (02) 773 816, Fax. (02) 777 6730 Colombia: IPRELENSO LTDA, Carrera 21 No. 56-17, 77621 BOGOTA, Tel. (571)249 7624/(571)217 4609, Fax. (571)217 4549 Denmark: Prags Boulevard 80, PB 1919, DK-2300 COPENHAGEN S, Tel. (032) 88 2636, Fax. (031) 57 1949 Finland: Sinikalliontie 3, FIN-02630 ESPOO, Tel. (9)0-50261, Fax. (9)0-520971 France: 4 Rue du Port-aux-Vins, BP317, 92156 SURESNES Cedex, Tel. (01)4099 6161, Fax. (01)4099 6427 **Germany:** P.O. Box 10 63 23, 20043 HAMBURG, Tel. (040) 3296-0, Fax. (040) 3296 213 **Greece:** No. 15, 25th March Street, GR 17778 TAVROS, Tel. (01) 4894 339/4894 911, Fax. (01) 4814 240 Hong Kong: PHILIPS HONG KONG Ltd., 6/F Philips Ind. Bldg., 24-28 Kung Yip St., KWAI CHUNG, N.T., Tel. (852)424 5121, Fax. (852)428 6729 India: Philips INDIA Ltd., Shivsagar Estate, A Block, Dr. Annie Besant Rd., Worli, BOMBAY 400 018, Tel. (022)4938 541, Fax. (022)4938 722 Indonesia: Philips House, Jalan H.R. Rasuna Said Kav. 3-4, P.O. Box 4252, JAKARTA 12950 Tel. (021)5201 122, Fax. (021)5205 189 Ireland: Newstead, Clonskeagh, DUBLIN 14, Tel. (01)640 000, Fax. (01)640 200 Italy: PHILIPS SEMICONDUCTORS S.r.I., Piazza IV Novembre 3, 20124 MILANO, Tel. (0039)2 6752 2531, Fax. (0039)2 6752 2557 Japan: Philips Bldg. 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108, Tel. (03)3740 5028, Fax. (03)3740 0580 Korea (Republic of): Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. (02)794-5011, Fax. (02)798-8022 Malaysia: No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Tel. (03)750 5214, Fax. (03)757 4880 Mexico: 5900 Gateway East, Suite 200, EL PASO, TX 79905, Tel. 9-5 (800)234-7381, Fax. (708)296-8556 Netherlands: Postbus 90050, 5600 PB EINDHOVEN, Bldg. VB Tel. (040)783749, Fax. (040)788399 New Zealand: 2 Wagener Place, C.P.O. Box 1041, AUCKLAND, Tel. (09)849-4160, Fax. (09)849-7811 Norway: Box 1, Manglerud 0612, OSLO, Tel. (022)74 8000, Fax (022)74 8341 Pakistan: Philips Electrical Industries of Pakistan Ltd., Exchange Bldg. ST-2/A, Block 9, KDA Scheme 5, Clifton, KARACHI 75600, TeI. (021)587 4641-49, Fax. (021)577035/5874546 Philippines: PHILIPS SEMICONDUCTORS PHILIPPINES Inc., 106 Valero St. Salcedo Village, P.O. Box 2108 MCC, MAKATI, Metro MANILA, Tel. (02)810 0161, Fax. (02)817 3474 Portugal: PHILIPS PORTUGUESA, S.A., Rua dr. António Loureiro Borges 5, Arquiparque – Miraflores, Apartado 300, 2795 LINDA-A-VELHA, Tel. (01)14163160/4163333, Fax. (01)14163174/4163366 **Singapore:** Lorong 1, Toa Payoh, SINGAPORE 1231, Tel. (65)350 2000, Fax. (65)251 6500 South Africa: S.A. PHILIPS Pty Ltd., 195-215 Main Road, Martindale, 2092 JOHANNESBURG, P.O. Box 7430, Johannesburg 2000, Tel. (011)470-5911, Fax. (011)470-5494 Spain: Balmes 22, 08007 BARCELONA, Tel. (03)301 6312, Fax. (03)301 42 43 Sweden: Kottbygatan 7, Akalla. S-164 85 STOCKHOLM, Tel. (0)8-632 2000, Fax. (0)8-632 2745 Switzerland: Allmendstrasse 140, CH-8027 ZÜRICH, Tel. (01)488 2211, Fax. (01)481 7730 Taiwan: PHILIPS TAIWAN Ltd., 23-30F, 66, Chung Hsiao West Road, Sec. 1. Taipeh, Taiwan ROC, P.O. Box 22978, TAIPEI 100, Tel. (02)388 7666, Fax. (02)382 4382 Thailand: PHILIPS ELECTRONICS (THAILAND) Ltd., 209/2 Sanpavuth-Bangna Road Prakanong, BANGKOK 10260, Thailand Tel. (662)398-0141, Fax. (662)398-3319 Turkey: Talatpasa Cad. No. 5, 80640 GÜLTEPE/ISTANBUL, Tel. (0212)279 2770, Fax. (0212)269 3094 United Kingdom: Philips Semiconductors Ltd., 276 Bath Road, Hayes, MIDDLESEX UB3 5BX Tel. (081)730-5000, Fax. (081)754-8421 United States: 811 East Arques Avenue, SUNNYVALE, CA 94088-3409, Tel. (800)234-7381, Fax. (708)296-8556 Uruguay: Coronel Mora 433, MONTEVIDEO, Tel. (02)70-4044, Fax (02)92 0601 For all other countries apply to: Philips Semiconductors, International Marketing and Sales, Building BE-p, P.O. Box 218, 5600 MD, EINDHOVEN, The Netherlands, Telex 35000 phtcnl, Fax +31-40-724825 SCD36 ©Philips Electronics N.V. 1995 All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner. The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or industrial or intellectual property rights. ### Printed in the USA 5120M/61M/CR1/pp848 Date of release: 02-95 Document order number: 9397 750 00013 This book was printed on recycled paper.